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Sugáe ly 5-100 microcomputer systems can easily handlé 100 million 
bytes. Because Morrow Designs™ now offers the first 26 megabyte hard disk 
memory for S-100 systems—the DISCUS M26™ Hard Disk System. 

Ithas 26 megabytes ofuseable memory (29 megabytes 
Unformatted). And it's expandable to 104 megabytes. 

The DISCUS M26™ system is delivered complete— 

a 26 megabyte hard disk drive, controller, cables and operating systerni- for 
ы 54995. Up to three additional drives can be added, 54495 apiece. ~. 

The DISCUS M26™ system features the Shugart 08 
Winchester-Npe sealed media hard disk drive, in a handsome metal cabinet 
With fan and power supply. 

The single-board 5100 controller incorporates intelli- 
dics to supervise all data transfers, communicating with the CPU ма : 
three 1/0 ports (command, status, and data). The controller has the abilily to 
generate interrupts at the completion of each command to increase system 
throughput. There is a 512 byte sector buffer on-board. And each sector canbe 
_ individually write-protected for data base security. i^ 

The operating system furnished with DISCUS M26" ( 
systems i is the widely accepted СР/М“ 2.0. 

- Seethe biggest, most cost-efficient memory ever inp 


"Асыр r To 


locally, write Morrow Designs;" 5221 Central Avenue, Richmond, СА ul Thini 
Р call (415) 524-2101, weekdays 10-5 Pacific Time. 


"CP/M is a frademark of Digital Research. V 
t. 
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After ten years of being an amateur 
computerist I have finally succumed and 
joined the ranks of commercial 
computerists; at least partly. Т follow 
in the footsteps of many who have gone 
before me. 

It had become apparent to me that 
there has been a significant void in the 
microcomputer magazine field. There are 
magazines catering exclusively to TRS- 
80, Appple, Pet, Heath, Kim, etc system 
users and broad based publications such 
as BYTE, Creative Computing, Interface 
Age and Kilobaud. Тһе result was that 
5-100 system users received only very 
minimal magazine coverage. There was a 
real need for a publication to cater to 
$-100 system users. After all, S-100 is 
far and away the most popular bus- 
oriented microcomputer system around. 
Its popularity is on the increase 
(last year saw the introduction of five 
new 5-100 mainframes), particularly with 
the adoption of the IEEE S-100 Bus 
Standard and the availability of the new 
$-100 16-bit microprocessor boards. 

The problem of no S-100 magazine 
was pointed out to me when two S-100 
Product manufacturers asked me for 
advice:on where they should advertise 
their products to effectively reach the 
largest number of S-100 system users for 
the advertising dollars they had to 
Spend. After all, magazine advertising 
is very expensive ( e.g. BYTE charges 
about $2,700 per page) and when only a 
Small percentage of the magazines 
readers are potential customers it means 
the advertiser is throwing away a lot of 
money advertising in the magazine. I 
really could not help these S-100 
suppliers. 


Editor's Page 
by Sol Libes 


It was then that the idea of an S- 
100 magazine started to take shape in my 
mind. 

I spoke to a number of people, 
including magazine publishers, to see if 
they were interested in publishing the 
magazine and succeeded in drumming up 
zero interest. Basically, they felt 
that the circulation would not be large 
enough for it to be financially 
worthwhile. One told me he felt that 
the S-100 bus was a thing of the past. 
Another explained the magazine 
publishing business to me.....that it 
would take at least three years to make 
it profitable and it would need a 
circulation of at least 50,000 
subscribers. 

I then started to think of 
publishing it myself. I am no 
businessman. Moreover, I am the kind of 
person who likes to take on a variety of 
projects and not tie myself to projects 
that take up all my time and run on for 
years. However, it has become apparent, 
after approaching many people, that the 
only way an S-100 magazine will come 
into existence is if I assume the 
responsibility. 

Many friends, who also believe in 
the need for this magazine, have pitched 
in to help me get it off the ground. 
You will see some of their names on the 
table of contents. But I will need а 
lot more help to make it a success. І 
am therefore asking for you 
help......subscribe, get your friends to 
subscribe. Send in articles, letters of 
criticism, suggestions, etc. Lets make 
$-100 MICROSYSTEMS "the" forum for S-100 
System users. 
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At Intersystems,. 
"dump is an instruction. 


Not a way of life. 


(Or when you're ready 2 IEEE 5400, will your 
computer be ready for you?) 


We're about to be gadflies again. 

While everyone's been busy 
trying to convince you that large 
buses housed in strong metal 
boxes will guarantee versatility 
and ward off obsolescence, we've 
been busy with something better. 
Solving the real problem with the 
first line of computer products 
built from the ground up to con- 
form to the new IEEE S-100 Bus 
Standard. Offering you extra ver- 
satility in 8-bit applications today. 
And a full 16 bits tomorrow. 

We call our new line Series 
ПУ And even if you don't need the 
full 24-bit address for up to 16 
megabytes (!) of memory right 
now, they're something to think 
about. Because of all the perform- 


ance, flexibility and economy 
they offer. Whether you're looking 
at a new mainframe, expanding 
your present one or upgrading 
your system with an eye to the 
future. (Series ІІ boards are com- 
patible with most existing S-100 
systems and all IEEE S-100 Stan- 
dard cards as other manufacturers 
get around to building them.) 
Consider some of the fea- 
tures: Reliable operation to 4MHz 
and beyond. Full compatibility 
with 8- and 16-bit CPUs, pe- 
ripherals and other devices. Eight 
levels of prioritized interrupts. Up 
to 16 individually-addressable 
DMA devices, with IEEE Standard 
overlapped operation. User-selec- 
table functions addressed by DIP- 
switch or jumpers, eliminating sol- 
dering. And that's just for openers. 
The best part is that all this 
heady stuff is available now! In 
our advanced processor — a full 
IEEE Bus Master featuring Memory 
Мар" addressing to a full mega- 
byte. Our fast, flexible 16K Static 
RAM and 64K Dynamic RAM . 
boards. An incredibly versatile and 


economical 2-serial, 4-parallel 
Multiple МО board. 8-bit A/D-D/A 
converter. Our Double-Density 
High-Speed Disk Controller. And 
what is undoubtedly the most flex- 
ible front panel in the business. 
Everything you need for a com- 
plete IEEE S-100 system. Available 
separately, or all together in our 
new DPS-1 Mainframe! 

Whatever your needs, why 
dump your money into obsolete 
products labelled ^IEEE timing 
compatible" or other words peo- 
ple use to make up for a lack of 
product. See the future now, at 
your Intersystems dealer or call/ 
write for our new catalog. We'll 
tell you all about Series 11 and the 
new IEEE S-100 Bus we helped 
pioneer. Because it doesn't make 
sense to buy yesterday's products 
when tomorrow's are already here. 


ШІСІ Ses tenons” 


Ithaca Intersystems Inc., 
1650 Hanshaw Road/P.O. Box 91, 
Ithaca, NY 14850 
607-257-0190/TWX: 510 255 4346 


AN INTRODUCTION 
TO CP/M—Part 1 
CP/M's Structure and Format 
by 


Jake Epstein 
Box 571 
Pittsfield, Ma. 01201 


This is the first part of tutorial series on CP/M, the 
most widely used disk operating system for S-100 based 
microcomputer systems, 


CP/M is an operating system written inch variety, but double density is 
to run оп 8080/8085/280 based micro- available on both systems and quad 
computers. It was written and is density is available for the 5.25 inch 
currently being supported by DIGITAL type. Thus, with a 4-drive dual-density 
RESEARCH, РО ВОХ 579, PACIFIC GROVE, system (DUAL REFERS TO THE ABILITY TO 
CALIFORNIA 93950. Their phone is 408- READ BOTH SINGLE AND DOUBLE DENSITY) the 
649-3896. Also there is a users group mass-memory size is 2 megabytes оп 8 
that provides a vehicle for the exchange inch diskettes. Such large memory 
of software, and currently, it has а capability is simply incredible when one 
quite large and varied list of languages considers computer size and price tag. 
and utility programs written to run 
under CP/M. There have Бееп several What really makes this operating 
versions of CP/M with the most current System so attractive for small system 
being ver. 2.0, and although at present users, however, is that it is hardware 
I do not have this version, I will be independent іп that once a user has it 
getting it in the near future. The running, he/she can use CP/M software 
system that I have now is version 1.4 without having to interface 15 by 
which DIGITAL RESEARCH continues to writing drivers for his/her system 
market апа support. Тһе prices that І configuration. This 15 made possible 
have at this writing are $100 for ver. because a group of routines that 
1.4 and $150 for 2.0 which includes a comprise ап area of the system called 
FLOPPY DISKETTE and complete "BIOS" (BASIC INPUT OUTPUT SYSTEM) is 
documentation. implemented when the user first gets 

CP/M up and running, and then the 

In the past, СР/М has been limited operating system calls this area when it 
to run mainly on 8 inch and 5 inch needs to do апу 1/0. Thus many 
"floppies", for although there have been combinations of terminal ports and disk 
tape versions, the majority of use has controllers can be used. Currently, 
been with disk-based systems. One of the there are many disk controllers being 
abilities of ver. 2.0 is hard-disk manufactured, and several worthwile 
compatibility which opens up the articles could be written for this 
possibility of tremendous mass memory column by users of different boards. I 
capability on a micro-computer. More on have the ТАКВЕ interface, апа in а 
this in future articles. CP/M uses future column, I will discuss the board 
"SOFT-SECTOR"  IBM 3740 format diskettes and my problems in getting it up and 
which store approximately 250,000 bytes running. There are four other areas in 
of data іп single density format on 8 the memory map of the system that I will 
inch disks and 70,000 bytes on the 5.25 mention here. BDOS (BASIC DISK 
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OPERATING SYSTEM) has routines that are of files on a disk, or execute a program 


used by the system to access its system file on a disk simply by using the 
disk drives and thus provides for file terminal that is logged on the system. 
management. Next month I will discuss Finally, there is an area of memory that 
how files are constructed, but for now I is used by programs that run under CP/M. 


will simply list the basic operations 

provided by BDOS: 
This area, the TPA (TRANSIENT PROGRAM 
AREA), begins at memory location 0100H, 
and programs are written by the user to 


SEARCH FIND A PARTICULAR FILE BY NAME run So that they can access areas of 
OPEN PREPARE A FILE FOR OPERATIONS BDOS, BIOS, and CCP to use routines 
ON IT already present in the system. Programs 

CLOSE CLOSE A PREVIOUSLY OPENED FILE accomplish this through various "SYSTEM 
RENAME GIVE A FILE А NEW NAME CALLS" апа thus as I stressed above, а 
READ BRING IN A RECORD (1 SECTOR/ program that uses these calls can be run 
128 BYTES) OF A FILE on any CP/M system. Finally, there is an 

WRITE STORE ON THE DISK ONE RECORD area from 00H to OFFH that provides for 
IN AN OPENED FILE buffers and system memory registers 

SELECT CHANGE THE LOGGED ON DISK DRIVE (special storage areas) that are used by 
the operating system. Below is a memory 


map of а 16K CP/M system based оп ап 
INTEL MDS system BIOS as provided іп 
DIGITAL RESEARCH also uses the term DIGITAL RESEARCH'S documentation. 
FDOS (FLOPPY-DISK OPERATING SYSTEM) 
which is actually the combined areas of 


BIOS and BDOS. The CCP (CONSOLE COMMAND In the memory map, TBASE, CBASE and 
PROCESSOR) can be compared to a keyboard FBASE represent the memory address of 
monitor, for the user converses with the the start of each area. ТВАЅЕ is always 
operating system via this area by using equal to 0100 but CBASE and FBASE change 
the command syntax of CP/M. їп other with different sized systems. Systems 
words, the operator can accomplish can be made larger or smaller according 
various tasks such as list а directory to the amount of main memory or other 


НЕ MM-103 DATA MODE 
AND COMMUNICATIONS ADAPTER 


5-100 bus compatible 
HIGH QUALITY 


FCC APPROVED 
-50 dBm sensitivity. Auto answer. Auto originate. Auto 


Both the modem and telephone system interface are 
FCC approved, accomplishing all the required protective dialer with computer-controlled dial rate. 61 to 300 baud 
(anywhere over the long-distance telephone network), 


functions with a miniaturized, proprietary protective 
coupler. rate selection under computer control. Flexible, 50Н- 
ware-controlled, maskable interrupt system. 


WARRANTY — — | : WARRANTY - ASSEMBLED 8 TESTED 
e year limited warranty. Ten-day unconditional 
Not a kit! (FCC registration prohibits kits) 


return privilege. Minimal cost, 24-hour exchange policy 
for units not in warranty. 

For Modem plus shipping — 
AND Coupler & handling === 


LOW PRICE— 3359 95— 


TN Call for further information: 
4-3 fy VOICE: (703) 750-3727 
SU MODEM: (703) 750-0930 (300 baud) 


A 


Write for brochure: 
First Lincolnia Bldg., Suite B1 
4810 Beauregard St. 

Alexandria, Va. 22312 
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consideration, but actually the memory 
map stays essentially the same with only 
the ТРА changing in size for different 
versions. One final note оп the 
operating system map is that a program 
may overlay the CCP or FDOS. What this 
means is that once the program is loaded 
from disk, it may use areas of memory 
previously occupied by the CCP or  FDOS 
as long ав they are not needed by the 
program. 

On power up, the operating system 
is either entirely or partially loaded 
into memory from a CP/M system diskette 
via а bootstrap loader sequence. Any 
diskette that has the operating system 
on it and is in drive 0 is called the 
"SYSTEM DISKETTE", and if you have а 
multiple drive system, only the 0 drive 
needs to have the operating system оп 
its Tracks 0 and 1 = contain the 
operating system while a directory of 
all the files оп a disk and their 
locations and the data files are found 
on the other tracks (2-76 on 8" disk or 
2-35 on 5.25" disk). Sector 1 track 00, 
the very first sector оп the disk, 
contains а loader program, which when 
placed in memory from 00-7FH will bring 
in the rest of CP/M when executed. Іп 
order to read sector 1, track 0, а 
bootstrap loader is used that can either 
be toggled іп via a "front panel" ог 
burned into a ROM and executed. Іп пу 
system which uses a ROM bootstrap, the 
entire process takes 1еѕѕ than 5 
Seconds. In some systems, different 
from mine, the BIOS or parts of BIOS 
such аз disk I/O is placed in ROM also. 
The BIOS contains boot programs to bring 
CP/M back in after a program has run, 


thus after executing a file, if BIOS is 
not altered, опе need only execute the 
area of BIOS used to bring in the 
system. Location 000H in memory is 
reserved for a jump vector to this boot 
routine, thus to bring in CP/M, all one 
has to do is to jump to location 00H. If 
bios is altered however, the entire 
System has to be rebooted from the 
starting point using a computer reset 
command to get control via either a ROM 
monitor, or а CP/M bootstrap that 15 
initiatied on reset. The main advantage 
of jumping to location 00 and not 


reseting the computer is that the former 
procedure will not alter the TPA or іп 
other words, the memory located from 
100H to CBASE (start of CCP). Once back 
at command level, the user may then save 
a memory image of the TPA that may be 
examined, modified, or executed at later 
time. 

T have included the following 
literal flowchart to help summarize what 
happens when СР/М is brought іп on а 
system after power up. 


In my system which uses the 
"Tarbell" controler апа BIOS, the 
following dialog occurs: 


TARBELL 36K CPM V1.4 OF 11-13-78 
2SIO VERSION. 

HOW MANY DISKS? 2 

A> 


—continued on page 10— 


ХХХХХХХХХХХХХХХХХХХХХХХАХХХХХХХАХХЖХХХХХХХХХХХХОХХХХХХХХХАХХХХХХХХАХХХХҮХХХЖХХЭХЖХЖХ 


ж 


ж 


ж BIOS (BASIC I/O SYSTEM) 3E00-3FFFH * 
ж ж 
doe FDOS (FLOPPY DISK OPERATING SYSTEM) BDOS-«BIOS ЖАКА 
* * 
* BDOS (BASIC DISK OPERATING SYSTEM) 3100-3DFFH * 
* (FBASE) * 
ХХХХХХХХХХОХХХХХХХХХХХХАХХХХХХХАХХХХХАХХХАХХХХХХХХХАХХХХХАХХХХХХХАХХХХХАХХХХХЖХХАХЖХАХЖ 
х * 
* CCP (CONSOLE COMMAND PROCESSOR) 2900-30FFH * 
* (CBASE) * 


ХХХХХХХХХХХХХОХХХХХАХХХХХХХХХХХХХХХХХХХХЖХХХАХХХХХХХЖЖККХХХХХАХХХХХАХХХХХХХХХХХХАХ 


х 


* 
* 
* 
* 
* 
* 
* 
* (TBASE) 
* 
* 
* 
* 
* 


TPA (TRANSIENT PROGRAM AREA) 0100H-28FFH 


kkkkkkkěkkkkkkkkěkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 


BUFFER AND STORAGE AREA 0000-FFH 


* 
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CP/M* VERSION 2 FOR TRS-80* MODEL ІІ NOW AVAILABLE 


АП Lifeboat programs require CP/M, unless otherwise stated. 


— ‘Software ботам 
DIGITAL RESEARCH = 7925 NL 25-9 
Dc FLOPPY DISKETTE OPERATING SYS- лова! (О INVENTORY CONTROL SYSTEM — Performs Г] 280 DEVELOPMENT PACKAGE — Consists of: 
м Бе Packages supplied on on diskette сотре еар = рога хы of адаи ved vay м ( Doe “ Um СА with global inter. Б» intra-line tacili- 
8080 sembli e - new items. ies. геюса! assembler, ilog/Mostek mne- 
utilities plus full documentation. CP/M available con- EIDOS SYSTEMS of tems on hand j Bak ordered cronies! conditional әлемнін and cross Feferance table 


figured for most popular computer/disk systems includ- 
ing: North Star Single, Double or Quad density, Altair 8" 


eo 


KISS — Keyed index Sequential Search, Otfers com- 
plete Multi-Keyed index Sequential and Direct Access file 


hard copy audit tri абе. Reports include cose 
Item List, Stock Activity, Stock Valuation and Re-order 


capabilities; (3) linking loader producing absolute Intel 
hex dk BW. i icio resi e enr Aerei ene $95/$20 


disks, Helios Il, Exidy Sorcerer, Vector MZ, Heath Н17: management. Includes built-in utility functions for 16 or List. Requires CBASIC-2 and 48K CP/M. .. $445/$25 п 

ог H89f, ты ICOM 3712 and iCOM Micro Dat 32 үл arthimetc, stingliniager pe rection and string E 8 201. 280 Мо nitor Debugger to break 3006 хат ae: 
plus many other configurations available off the shelf compare. Delivered as a relocatable linkable module in О ANALYST — Customized data entry and reporting sys- © registers w 555 when onde OO еке 
нийн ...8145/$25 Microsoft format for use with FORTRAN-80 or COBOL- tem. User specifies up to 75 data items per record. Inter- Remnbly dieptays $35 when ordered with 220 Develop. 

CPIM version 2 (not all formats available купеде OD whch ир лел атн АНЕ -5335/523 асе „даа entry. retrieval, and фе (аску көкө 5 Dun 'ackage 360/310 
pen Беър 222264 information management ea istic STEL — Disk based disassembler to Intel 8080 or 

O MP/M* 8300/850 С KBASIC — Microsot Disk Extended BASIC win al generator provides customized repons using selected TDUXitan 280 source code, listing and cross relerence 


© KISS facilities, int мек, integrated by implementation of nine 


records with ICA break-points for та ерен 


Мез. Intel ог TOUNEN pseudo ops optional, Runs on 


additional in language. Package includes tion. Requires 24 x 80 CRT, printer and 48K ..$85/ 
T KISS.REL as as described above, and a ERA list system. ... кори 5 ..8225/915 D DISILOG — P E 5 мж вээ 
uet ` pogam ss: та. 6808446 Г1 LETTERIGHT — Program to create, edit and type let- кти. ю 2300 Мэн noe 
Lor мен To licensed users of BIG So MEAS tors or other documents, Has faciles to enfer, display. ( files. Runs on 280 only y4 908/810 
delete and move text, with good video screen presenta- O XASM-68 — mbler with nested 
МАС — 8080 Macro Assembler. Full Intel macro defini- я tion. Designed to integrate with МАО Гог form letter тай- conditionals and ieudo operations. Assem- 
tions. Pseudo Ops include АРС, IRP. REPT, TITLE. ings. Requires CBASIC-2 . $179/$25 bles from standar mnemonics to Intel 
PAGE, and MACLIB. Z80 library included. Produces Intel Me 7723 / C] NAD Name and Address See lO system — interactive. NO: 222. ext 25 
absolute hex кошрщ pus symbots file tor use by SID (see 97727 ^ mail list creation and maintenance program with output О XASM-65— ЕКЕН Technology 
below) $85/$15 р as foll repons yale тавгаа data or resvicted pecan MCS6500 mnemi 5200/525 
О SID — 8080 symbolic debugger. Full trace, pass count 20% Жоп tor mad цен тени аунап ell bag т Г] TEXTWRITER Ill — T - 
and break-point program testing system with back-trace transfer of selected records to create new files. Requires е uis ewe Ud и ех! стане: ю justiy and Да 


and histogram utilities. When used with MAC, provides 
full symbolic display of memory labels and equated val- 
МӨ  ccsicesdaectepaabavncesss 22...2.570/515 


C] 2810 — As above for 280. Requires 280 CPU $95/525 


a 


D 


TEX — Text formatter to create paginated, page-num- 
bered and justified copy from source text files, directable 
to disk or primer ......................... $70/$15 
DESPOOL — Progra to permit simultaneous printing 
of data from disk while user executes another pogan 
from the console BEREE CHOSE 


MICROSOFT 


SUPER-SORT | — Sort, merge. extract utility as abso- 
lute executable program or linkable module in Microsoft 
format. Sorts fixed or variable records with data in binary, 
BCD, Packed Decimal, EBCDIC, ASCII, floating, fixed 
point, exponential, field justified, etc. etc. Even variable 
number of fields per record! 5225/525 


SUPER-SORT Il — Above available as absolute pro- 
gramonly .... ..$175/$25 


SUPER-SORT M — As without ол SELECTIEXCLUDE 


го 


WORD-STAR — Menu дпуеп visual word processing 
0) system for use with standard terminals. Text formatting 
6 performed on screen. Facilities for text paginate, page 
number, justify, center and underscore. User can pnnt 
one document while simultaneously editing a second 
Edit facilities include global search and replace, read/ 
wnte to other text files, block etc. Requires CRT 


CBASIC2 . . $79/$20 
QSORT — Fast sort/mer ege program for files with fixed 
record length, variable field length information, Up to five. 
ascending or descending keys. Full ир of input files 
created. . - 595/520 


умен 
777 ЖЕРІ 


GRAMAM-DORIAN SOFTWARE SYSTEMS 


LJ GENERAL LEDGER — An on-line system; no batch- 
© ing is required. Entries to other GRAHAM-DORIAN ас- 
(€ counting packages are automatically posted. User estab- 
lishes customized C.O.A. Provides transaction register, 
record of journal entries, trial balances and monthly clos- 
ings. Keeps 14 month history and provides comparison of 


Clude insertion of text during execution from other disk 
files or console, permitting recipe documents to be 
created from linked fragments on other tiles. Has facilities 
lor sorted index, table of contents and footnote insertions. 
Ideal for contracts, manuals, etc. Now compatible with 
Electric Pencil -**** prepared files. . ..$125/$20 
5 POSTMASTER — А comprehensive package for mail 
151 maintenance. Features include keyed record extrac- 
tion and label production. A form letter program is in- 
cluded which provides neat letters on single sheet or con- 
tinuous forms. Requires CBASIC-2 3150315 


O WHATSIT?**** interactive data-base system using 


мос lags to retrieve information by subject. Навһ- 
and random access used for fast Грона. duse 
с ASIC-2 .......... . ..... 5125/828 


О XYBASIC interactive Process | Control BASIC — Full 


disk BASIC features plus unique commands to handle 
bytes, rotate and shift, and to lest and set bits. Available 


3 вд — Dk Extended REND. nee terminal with address: bsitioning |5/525 сштеп! u yaar with previous year. Requires CBASIC-2. Du repel Land ады versions. хэмлэн 
&) able length file records. Е 325 g WORD-STAR/ н Е Сс Аз above with ор. п ACCOUNTS уд ОЛОН — = Extended Disk or Extended ROMabie ......$395/$25 
© tion for producti 'ersonalizi documents - Jains уе! г list а! 
O BASIC COMPILER та Language сорар wih @ with тай list rom Data-Star or NAD. ‚.$575/$25 © check register. Performs cash flow analysis. Flexible — o [э-нын Захиалах Macro Assersttes Language — 
ара кы EN Deu зыш 1 wonp.sran сараа моме — to Wn DEUS ө ше wm era, ос в TUNE UTE: 
@ standard Microsoft e 19 FORTRAN ч СОВОГ-80 поеме ^ Agia ine can make partial payments. Automatically posts to езвог ама blot lancuane with WF THEN БЕ, LOOP 
Macro-80. Also linkable to or COB ‘sophisticated и: уе one of the many GRAHAM-DORIAN general ledger or runs as stand alone an asse! г language wi Lf ООР- 
code modules .... ...$350/$25 standard terminal figurations in the distribu- system Requires CBASIC-2. Supplied in source REPEAT-WHILE, DO- “END, BEGIN: END constructs 
FORTRAN-80 — ANSI 66 (except for COMPLEX) fon vean o OR ME ere € Бетон oss Base оа oem 
plus many extensions. Includes relocalatie object com. WORD-MASTER Text Editor — In one mode has ACCOUNTS RECEIVABLE — Crestes vial balance @ and mantain multi Key data bases. Prints formatted, 


piler, linking loader, library with manager. Also includes 
МАСЯО-80 (see below) 5400/525 


superset of CP/M's ED commands including global 
searching and replacing, forward and backwards in file, In 


g 
© reports. prepares statements, ages accounts and records 
М) invoices. Provides complete information describing cus- 


sorted reports with numerical summaries or mailing 
labels.Comes with sample applications, including Sales 


О COBOL-80 — Leve! 1 ANSI 74 standard COBOL plus sors tomer payment activity. Receipts can be posted to ditter- 

© тоз of Level 2. Full sequential, relative, and indexed Ho Sena! acdressabie cursor воееп ог 31231428 ent ledger accounts. Entries automatically update у куню, Payables. ын, бес Regis- 
м rt with variable file names. STRING, UNSTRING, GRAHAM-DORIAN general ledger or runs as stand alone ег, а! ient/Patient Appointments, etc. Requires 
T COPY. CBASIC-2 Version 2.Supplied in source code.$295/$20 


eon 


ео 


© IPUTE, VARYING/UNTIL, EXTEND, CALL, 
SEARCH, 3-dimensional arrays, compound and ab- 
breviated conditions, nested ЇР. Powerful interactive 
Screen-handling extensions. Includes compatible as- 
sembler, linking loader, and шинжээ sig тепабег 
as described under МАСНО- 


МАСВО-80 — 8080/280 Macro Assembler. Intel and 
Zilog mnemonics supported. Relocatable linkable output. 
Loader. Library Manager M: Cross Reterence List 
utilities included .... . ..$149/$15 


XMACRO-86 — 8086 cross assembler. All Macro and 
utility features of MACRO-80 package. Mnemonics 
Slightly modified from intel А5МВ6. е. Сор баја 
sheet available. ..... 


дарау system for key o disk dabicaplore. Меги driven 


with built-in learning ац Jyenlicalion by length, 
mask, attribute (i, уй сазе, numeric, auto 
dup., etc.). Вий: с capabilities using keyed 


data, constants а! мед values. Visual feedback for 
ease of forms design. Files compatible with all CP/M- 
MP/M supporied languages Неди 32К СР/М 

5350/535 


© 
22 
i" DATASTAR — Protessional forms control entry and 
е 


СВАЗ(С-2 Disk Extended BASIC — Non-interactive 
М) BASIC with pseudo-code compiler and runtime interpre- 
ler. Supports full file control, chaining, bia and ex- 
tended precision variables, etc. ... $109/$15 


— 


PASCAL/M — Compiler genergtes Р code from ex- 


system. Requires CBASIC. Зорро in source. 
УА ..$495/$35 


PAYROLL SYSTEM - — - Maintains empio; master 
file. Computes payroll withholding for FICA, Federal and 
State taxes. Prints payroll register, checks, quarterly re- 
ports and W-2 forms. Can generate ad hoc re 5 and 
employee form letters with mail labels. Requires 
CBASIC-2. Supplied in source code. .......$495/$35 
INVENTORY SYSTEM — Captures stock levels, 
costs, sources, sales, ages, turnover, markup, etc. 
Transaction information may be entered for reporting 
salesman, type of sale, date of sale, elc. Герона ауа! 
able both for accounting and decision meno. Requires 
CBASIC-2. Supplied in source code. ... 5335 


JOB COSTING — Designed for шы contractors. 


eeu 


®©Г1 


еп 


eu 


[ÀJ СРМ/З7АХ — Has full range of functions to create or 


re-name an IBM 3741 volume, display directory infor- 
mation and edit the data set contents. Provides full file 
transfer facilities between 3741 volume data sets and 
CP/Mfiles ...... .$195/$10 


BASIC UTILITY DISK — Consists of (1) CRUNCH- 
14 - Compacting utility to reduce the size and increase 
the speed of programs in Microsoft Basic and TRS-80 
Basic. (2) DPFUN - Double precision subroutines for 
computing nineteen | iranscendental funcions including 
Square root. natural log, log base 10, sin, arc sin, hyper- 
bolic sin, hyperbolic arc sin, etc. Furnished in source on 
diskette and documentation ........ ..$50/$35 


THE STRING BIT — Fortran character string han- 


(1 EDIT-80 — very fast random access text editor for text tended lant ди ti find, fil 
- guage imple! f standard PASCAL. © Те RIAN ing. Routines to find, fill, pack, move, separate, con- 
© with or without ма eters. шаг anire пе сот Ф Supports jm Гвай опа! procedure 9 то belused erii Moe tracking Er. Нам ВО e catenate and compare character strings. This package 
mands supported. File compare utility inclut calls and the 5! jure type. Provides con- penses. User establishes customized cost categories completely eliminates the problems associated with 
MICRO FOCUS venient string har ‘Capability with the added variable and job phases. Permits comparison of actual versus character sung handing in ee Supplied with 
үре STRII пүре files allow Y memory, image VO. estimated costs. Automatically updates GRAHAM- SOUCA .........................-....--.. 545/815 
o STANDARD CIS COBOL т, ANS! 74 COBOL uires 56K СР/ 5350/530 DORIAN onerat ledger or runs as stand alone system. В BSTAM — Utility to link one ‘computer to another also 
Ф 
© ANSI level 1 Supports many leatures to level? ciuding 8) PASCALIZ — 280 naive code PASCAL comple АРАНТЦЕЙТ MANAGEMENT SYSTEM ща Speed (no conversion lo hes), with СНС Block сонго 
dynamic loading of COBOL modules and a full ISAM file. Produces D e ROMable re-entrant code. АЙ inter. o APARTMENT MAI EMENT SYSTEM — ғ. check for very reliable error detection and automatic re- 
facility. Also, program segmentation, interactive debi © fang to GPM trough те support toan. ne pack: р nancial mansgameni syetona: Юк recs and secu try. We use it! It's great! Full wildcard expansions to 
and powerful interactive extensions to support protected age includes compiler, companion macro-assembler and © deposits отарын proie POM send * СОМ, etc. 9600 baud with wire, 300 baud with 
and unprotected CRT screen formatting "от COBOL source for the library. Requires 56K and 280 CPU. еер MC On Annual ке, ee eee phone connection. Both ends need one. Standard and M 
п Ч hows : i 
programs used with any dumb terminal .....$850/$50 Ven? etudes ай of Jensen/Wirth up ^n гэл through тілі ене Й Ме CBASIG-2. Sup- versions can talk to one another. Compatible. 115003 
в FORMS 2 — CRT screen editor. Quiput is COBOL data Version 3 Upgrade variant records and Eus plied in source code. ................. $495/$35 version анд алые 
© descripions for copying into programs редей2/80. ... O CASH REGISTER — Maintains files on daily sales. 
Automatically creates a query and update гат of in- * * * ж Ж * 
doxed fles Leng CRT protecied and unprotected Screen Г] PASCAL/MT — Subset of standard PASCAL. Gen- (© Files data by sales person and Пет, Tracks sales, over 
formats. No programming experience needed. Output @ erates ROMable 8080 machine code. Symbolic debugger @ rings, refunds, payouts and total net deposits. Requires 
program drechy compiled by CIS COBOL (standard) Ф incuded. Supports interrupt procedures and BCD arith- CBASIC-2. Supplied in source code. ....... . $490938 
$200/$20 тейс for па. vanables. c м пе МО аге assembly lan- 
wage interface supported. Lacks numeration and О tiny C — Interactive interpretive system for teaching 
C] HDBS — Hierarchical Data Base System. CODASYL Record daia types; Manual frons BASIC 0 DOCA ® sturtured programming techniques. Manual includes ful 
опасва - mE SETs. AS тт Source for PASCAUMT run time package. Requires source шдэ 5 
and TRAVERSE d Ба. SET ordering s MAG: бм пеон года: Research 2 5000 рвов с Comma вн = Suppers most majo ears 
sorted, FIFO, LIF prior. One to many set rela- е, теа г г 8080 
tionship supported. Read/Write protection at the FILE . we Ф binary output. Lacks ate ект хн tong d 2 loet type HEAD CLEANING DISK ҮҮТ Cleans the drive 
level. Supports FILEs which extend over multiple floppy / апа зас 8 register class specifiers, Documentation in- read/write head in kette absorbs loose 
or hard disk devices. дена 5 cludes "C" Programming Language book by Kernighan & oxide particles ! deother foreign particles 
О MDBS — Micro Data Base, Full network data A li 4 [== сылап ма баарга 51 10/315 that might hind formance of the drive head. 
base with all featur multi-level Read/ Lasts at least 3 months with daily use. Specify 5" or 8. 
Write protection f CORD and ITEM g WHITESMITHS C COMPILER — The ultimate in Pipoy Diek Kit 320. еа./346. for 3 
xplicit representat ne to one, one to many, many © systems software tools. сез faster code than Pas- із! -- Template and instructions to modi! 
10 many, and many to one SET relationships. Supports _ STRUCTURED SYSTEMS GROUP @ cal with more extensive facilities. Conforms to the full ыи ‘sided 574 diskettes for use ys second side in x 
multiple owner and multiple record types within SETS. O GENERAL LEDGER — interactive and flexible sys- UNIX*** Version 7 C language, described by Kernighan le sided drives 812.50 
НОВ5 Мез are fully compatible. tem providing proof and report outputs. Customization and Ritchie, and makes available over 75 functions for 9 ща ` 
О MDBS-DRS А р 8 of COA created interactively. Multiple branch account performing 1/О. string manipulation and storage айоса- О FLOPPY SAVER Protection for center holes of 5%” 
hich m А Арақ k ing centers. Extensive checking performed at data боп. Linkable to Microsoft REL Мез. Requires GOK CP/M floppy disks. Only 1 needed per diskette. Kit contains 
ah EM REG SETs are al этү ithout entry for proof, COA correctness. ac Journal entries .$630/$30 centering post, pressure tool, tough 7-mil mylar reintorc- 
и reed! may be batched prior to posting. Closing procedure "ACA ing т Installation хов. and rings for 25 di 
changing existing data. automatically backs up input files. Now includes State О POLYVUE/80 — Fullscreen editor for апу CRT with ч“. me Сүүл 
Нова 280 varaion ; ji ment of Changes in Financial Position. Requires Ф pp regret меси oe Re-orders of rings only $7. 
MDBS ORS 280 version. an ARCDUNTS RECEIVABLE vecina wrap around for word processing, operations for manipu- D PASCAL USE, Мон ВЕРОВТ- ву 
8080 Version available at $75. extra. - Open Rem system lating blocks of text, and comprehensive 70 page manual. Jensen and Wir rð fextbook on the гай: 
with output for internal aged reports and customer-ori- 4135/315 guage. Recomm for use by PascaliZ. PascalM 
280 version requires 20K RAM. 8080 version requires ented statement and billing purposes. On-Line Enquiry n POLYTEXT/80 - ще : i and Pascal/MT users. k 2 ..$8 
24K RAM. (Memory requirements are additional to CP/M permits information for Customer Service and Credit de- — Тех! formatter for word Process ПІ THE C PROGRA! IN GUAGE 
and application program.) partments. Interface to General Ledger provided if both ® applications. Justifies and paginates source text files. Wil Kemighan and = By 
When ordering HDBS or MDBS please specily i! Ihe ver гугіете used. Нисийгэв СВАБКС-2 ..... коп койо Support сета language. Reco е by BDS С, tiny С, and 


Shopping « a 
List No. 


Software for most popular 8080/280 computer disk systems including 


sion required is for 1) Microsoft 180 i.e FORTRAN-80. 
COBOL-80, BASIC COMPILER. 2) MBASIC 4. XX. or 3) 
BASIC-80 5.0. 


Г1 ACCOUNTS PAYABLE — Provides aged state- 
ments of accounts by vendor with check writing for 
selected invoices. Can be used alone or with General 
Ledger and/or with NAD. Requires CBASIC-2$699/$25 


Pnces and specifications subject to change without notice 


ТА 


variable pitch justification and motion optimization. 


vada $85/$15 


О ALGOL-60 — Powerful block-structured language 
compiler featuring economical run time dynamic alloca- 
lion of memory. Very compact (24K total RAM) system 
implementing almost ай Algol 60 report features plus 
many powerful extensions including string handling direct 
disk address 1/О etc. Requires 280 CPU ... "190/820 

“CPIM is a trademark о! Digital Research. 

80 is a trademark of Zilog, Inc 

МІХ 15 a trademark of Bell Laboratories 

HATSIT? is a trademark of Computer Headware. 

***** Electric Pencil is a trademark of Michael Shrayer Software, 
Ж TRS-80 is a trademark of Tandy Corp. 


С ҮСРМ for Heath, TRS-80 Model | and PolyMorphic 8813 are 
modihed and must use specially compiled versions о! system 
and apphcations software. 

@ Modified version available for use with CP/M as implemented 
on Heath and TRS-80 Model | computers: 


User license agreement for this product must be signed and 
returned to Lileboat Associates belore shipment may be made 
бтв: product Includes/Excludes the language 
manual recommended in Sundries and Notions above. 


NORTH STAR, iCOM, MICROPOLIS, DYNABYTE DB8/2 & DB8/4, EXIDY 


Whitesmiths C uses. ........................ 812 


Orders must specify disk 
systems and formats: 

e.g. North Star single, 
double or quad density, 
ІВМ single or 20/256, 
Altair, Helios Il, 
Micropolis Mod ! or Il, 
5%" soft sector (Micro 
iCCM/SD Systems 
Dynabyte), etc. 


Prices F.O.B. New York. 
shipping. handling and 
О. charges extra 


Manual cost applicable 
against price of 
subsequent software 
purchase. 


The sale of each 
proprietary software 


SORCERER, SD SYSTEMS, ALTAIR, VECTOR MZ, MECCA, 8” IBM, 
HEATH H17 & H89, HELIOS, IMSAI VDP42 & 44, REX, NYLAC, 
INTERTEC, VISTA V80 and V200, TRS-80 MODEL І and MODEL ІІ, 
ALTOS, OHIO SCIENTIFIC and IMS 5000 formats. 


"“Тпе Software Supermarket is a trademark of Liteboat Associates 


package conveys a 
license for use on one 
system only. 


Lifeboat Associates, 2248 Broadway, N.Y., М.Ү. 10024 
(212) 580-0082 Telex: 220501 6 New number! 7 


—continued from page 8— 


1. TURN ON POWER 


—————————-——-—-——— 


2. PLACE SYSTEM DISKETTE 
IN DRIVE 0 


3. HIT RESET 


INITIALIZES ROM BOOTSTRAP LOADER 
SETS DISK DRIVE 0 TO TRACK 00,SECTOR 1 


4. HIT RUN 


ROM BOOTSTRAP LOADER LOADS IN BOOT 
LOADER FROM SYSTEM DISKETTE TO LOCATION 


00-7FH 


COMPUTER JUMPS OUT OF ROM BOOTSTRAP TO 
THE TO THE BOOT LOADER AT LOCATION 00 


CCP, BDOS, AND BIOS ARE BROUGHT IN AND 
PLACED IN MEMORY AT THEIR RESPECTIVE 
LOCATIONS. 


THE COMPUTER JUMPS TO ROUTINE IN BIOS 
CALLED BOOT WHICH PRINTS A MESSAGE 
ASKS THE OPERATOR FOR THE NUMBER OF 
DISK DRIVES IN THE SYSTEM. 


5. TYPE IN AT THE CONSOLE 
THE NUMBER OF DISK 
DRIVES IN SYSTEM 


BIOS LOGS THE NUMBER OF DISKS, PLACE 

A JUMP INSTRUCTION TO A BOOT ROUTINE 
IN BIOS AT LOCATION 000, AND THEN 
PLACES A JUMP INSTRUCTION TO FBASE 
(START OF BDOS) AT LOCATION 005H WHICH 
IS FOR SYSTEM CALLS BY PROGRAMS IN 

THE TPA. 


6. PROMPT IS PRINTED 
ON CONSOLE TERMINAL 


In the above, 36K is the CP/M 
memory Size, V1.4 stands for version 1.4 
of CP/M, and 2510 VERSION is the type of 
I/O board used in my system. Т typed in 
2 to the question "HOW MANY DISKS?" 
because I currently have two disk 
drives, and finally the prompt "A>" 
signifies that drive "A" (drive 0) is 
the currently logged on disk. Also, 
memory locations 00-02 contain (C3 03 
8A) which is the jump to the boot 
routine in BIOS as mentioned above, and 
locations 05-07 contain (C3 03 7D) which 
is the jump to BDOS to service system 
calls. All values in hexadecimal. 

Hopefully, the above text will give 
an idea of the structure апа initial 
workings of CP/M on power up and reset. 
Next month I will discuss the basic 
command syntax of CP/M, file structure, 
and diskette mapping. In future 
articles, I will discuss modifying CP/M 


for different hardware confurations, 
using system calls, running utility 
programs, and implementing I/O STATUS 


BYTE options. 
NEXT MONTH 
PART 2 
CP/M's File Structure and Command Syrtax 
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SYSTEM IS READY FOR COMMAND PROCESSING 


NEW PRODUCTS 


CP/M VERSION 2.0 MP/M SOFTWARE RELEASED 


DIGITAL RESEARCH, P.O. Box 579, 
Pacific Grove, СА 93950 has announced 


the release of CP/M Version 2.0. 


2.0 allows for data file management for 
The CP/M BDOS, 
completely table drive, allows de- 
finition of as many as 16 logical drives 
It includes 
new random access features, separation 
of files by user tag number and read- 
only protection of individual files. 
Other enhancements are contained in the 
New manuals 


up to 128 megabytes. 


of up to 8 megabytes each. 


modules and utilities. 
include a "System Alteration Guide" 


an "Interface Guide" for customizing the 
CP/M 2.0 is upward competible 


software. 
with previous releases of CP/M. 


. Also introduced is MP/M 1.0, which 
is a multiprogramming monitor for 8080, 
MP/M is also 
upward compatible with CP/M and uses the 


280 and 8085 processors. 


CP/M 2.0 file structures. 


8-100 MICROSYSTEMS 


MODIFYING THE 
. SDS VDB-8024 


by 


Jon Bondy 
Box 148 
Ardmore, Pa. 19003 


This article describes how to alter the SDS-8024 Video 
Board to support all the sophisticated screen editing 


functions of UCSD PASCAL. 


Further, 


it contains a routine for 


adding PEEK and POKE like functions to UCSD PASCAL and a 
PASCAL program for burning in an EPROM. 


S-100 Bus boards are available with 
an enormous range of functions, perfor- 
mance and prices. My experience with SD 
Sales (now SD Systems) computer products 
has been that they are good quality and 
reasonably priced. Their ExpendoRam 
boards are an exception, being of good 
quality and rock bottom prices. 

When SDS introduced their 24 by 80 
character VDB-8024 video board I was 
excited. since the limitations of my 
memory-mapped 16 by 64 character board 
were beginning to cause problems for me. 
I investigated their product, and 
discovered that it was a "smart" board, 
with an on-board Z-80, 2708 EPROM 
firmware to control the board's 
functions, a 2708 character EPROM, and 
one of the (at that time) new CRT 
controller chips, the SMC 5027. The kit 
was a bit steep at $320, but the fact 
that I could customize it made it 
attractive. 

The board works as a small computer 
System in its own right, accepting data 
from the main computer and processing it 
in order to achieve the same functions 
as a smart terminal. Specifically, it 
must move the character data into the 
refresh RAM at the proper location, move 
the cursor around, and perform whatever 
"smart" functions, such as random cursor 
motion, are required. The CRT 
controller chip, the SMC 5027, shares 
the refresh RAM with the Z-80, as a DMA 
device, so that about one half of the 
memory accesses are made by the 5027 and 
the remainder by the 7-80. 

Those of you who have written 
drivers for the memory mapped video 
boards will already know that scrolling 
all of the characters on the screen up 
one line is а time consuming business. 
Most of the CRT controller chips provide 
ways to perform scrolling rapidly, 
usually by changing the upper left 


5-100 MICROSYSTEMS 


character. The 5027 does this, and 
although it increases the speed of the 
VDB-8024 board, it also complicates the 
firmware which drives it. At any given 
time, the 5027 may "think" that the top 
of the screen is at any one of 24 
locations in the refresh memory, and in 
order to function correctly, the 
firmware must keep track of what the 
5027 is thinking. In order to fully 
understand the firmware listing given at 
the end of the article, you will 
probably have to read articles or data 
Sheets on the 5027, since a complete 
discussion of the 5027's features is 
beyond the scope of this article. Note 
that discussions of the 5027 have 
appeared in BYTE and INTERFACE AGE 
magazines. 

I have used computers for over 
twelve years, and have become a 
confirmed high level language freak, 
since the novelty of machine language 
wore off about seven years ago. I run 
the UCSD PASCAL operating system ex- 
clusively (except when I am forced to 
use CP/M to re-write my BIOS), so it was 
important to me that whatever "terminal" 
I used could support that software 
system. UCSD PASCAL includes a sophis- 
ticated screen editor, and thus requires 
Some special CRT functions, such as 
erase-to-end-of-line, erase-to-end-of- 
Screen, random cursor addressing, home 
and cursor motion controls. The VDB- 
8024 as delivered included а set of 
firmware which supported most of these 
features (and some additional features 
which I did not need), but did not 
support the erase-to-end-of functions 
which I required. Т set out to find out 
how hard it would be to modify the 
board. 

The first step was to get the kit 
working without any changes. and then to 
attempt the modifications. The kit went 
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together easily, and there were по 
problems getting the board to function 
as advertised. Опе flaky RAM chip was 
annoying, but since SDS would not send 
me a replacement without my first 
Sending them the chip, I replaced it 
myself rather than go without the board 
for the weeks the trade might take. At 
the time that I purchased the kit (May 


of 1979), the documentation was not 
exactly correct for the board, but I 
assume that that has been improved. 

SDS includes a listing of their 
firmware in their instruction book and 
So it was easy to start thinking about 
how to modify their software. Му first 
observation was that, although their 
hardware was fine, their software 
practices and documentation were rather 
poor. For instance, they never gave the 
ports which controlled the SMC 5027 any 
logical names, using hex instead, as in 
the following: 


OUT (ЗАН),А 
LD A,065H 
OUT (81H) 
LD A,0D7H 
OUT (80H) 


This made it rather difficult for 
me to read at first, especially since 
there were no comments about the 5027 
ports. When I re-wrote their firmware, 
I used logical names instead, as in the 
following: 


OUT (RESET),A 
LD A,065H 
OUT (REG1) 
LD A,0D7H 
OUT (REG3) 


It would have been nice if the 
other hex constants could have been 
named also, but they correspond to a 
Series of bit patterns for controlling 
the 5027, and are not amenable to short 
names. 


In addition, there appears to be а 
hardware feature on their board which 
allows one to turn off the SMC 5027's 
access to the refresh RAM in order to 
allow the Z-80 to access it more 
rapidly. Since this function was not 
documented anywhere, its use had to be 
deduced from the schematics. Unfortun- 
ately the schematics were not exactly 
correct either (more on that later). 


SDS included a number offunctions 
of which UCSD PASCAL would not take ad- 
vantage, including reverse scrolling, 
underlining, highlighting, blinking, and 
multiple terminal "speeds". I decided 
to remove them from my version of the 
firmware. Also, I did not want the 
auto-line-feed feature which SDS 
included, so I re-wrote that area of the 
firmware. 
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Since I had written my own driver 
for my memory mapped video board pre- 
viously, I had incorporated a somewhat 
unusual manner of performing random 
cursor addressing. Although there is no 
standard for this function, many 
terminals do it by accepting an ESCape 
character first (1BH), followed by the 
x- and the y- locations for the cursor. 
One minor problem with this is that it 
would seem that only two characters 
should be required for this function, 
rather than three. The real problem, 
however, is that it does not allow for 
random x- and y-addressing indepen- 
dently. My non-standard method did, so 
I changed their firmware again. 

My method uses (wastes?) the ASCII 
characters from 80H to 8FH by assigning 
them the following values. If the 
character is between 80H (128) and 0р1Н 
(209), it controls the x-address, and 
the new x-address may be found by 
subtracting 128 from the character. 
This allows me to set up x-addresses 
from zero to 81. If the character is 
greater than OdlH, it controls the y- 
address, and the new address may be 
found by subtracting 210 from the 
character. This allows me to set up y- 
addresses from zero to 45. 

Reading through the SDS firmware 
waS both interesting and confusing, 
since I had never seen such control 
oriented code before. The entire "com- 
puter system" was dedicated to the 
single-minded function of processing 
characters from the computer to the 
screen. After the power-on reset 
occurs, the firmware simply sets up the 
5027, enables interrupts, and HALTS! ІЁ 
has nothing to do until the first char- 
acter comes in from the main computer. 
When the character arrives the processor 
will be interrupted, so it made sense to 
write the program that way. Sequences 
which in a "normal" program would make 
little sense began to make sense as I 
realized that sections of unconnected 
code would be connected when interrupts 


began to happen. 

Because it is interrupt driven, the 
real action starts at location 38H, 
where the interrupt service routine 
(actually the entire program) starts. 
It inspects the character to see if it 
is a control character or a displayable 
character. For control characters, it 
manipulates the Z-80 registers and the 
5027 registers to accomplish the 
required function. For displayable 
characters, it simply displays them and 
moves the cursor. 

Since I do not use CP/M unless I 
have to, I wanted to write this new 
firmware under UCSD PASCAL. Each re- 
lease of UCSD PASCAL after Version 1.4 
has included ап assembler for the 
machine on which the software runs; in 
my case it was a 2-80. ТЕ seemed as if 
I could in fact develop the assembler 
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Source and object using the UCSD system 
and its nice screen editor. 

I then came to the question of how 
to program the EPROM from PASCAL. I had 
intended to program the new EPROM using 
a Cromenco Bytesaver EPROM programming 
board, to which I could get temporary 
access. The Bytesaver actually burns an 
EPROM by interpreting a "write" access 
to an EPROM memory location as a request 
that that EPROM location be programmed. 
It seemed that if I could write a PASCAL 


program which repeatedly wrote the re- 
quired bit pattern into a particular 
location in memory, then the EPROM could 
be programmed in PASCAL. Іп BASIC, this 
would correspond to using the "peek" and 
"poke" facilities. 

The UCSD Assembler has many 
features, among them the ability to 
generate relocatable code and the 
ability to assemble many modules in one 
pass, keeping track of them in a kind of 
directory at the start of each file. I 


PROGRAM LISTING 1 
POKE FUNCTIONS 


PEEK & 
FUNC MEMREAL »1 
РОР ІХ 
POF ІҮ 
РОР ІҮ 
FOF HL 
LI Est HL? 
LI! 1,0 
FUSH ПЕ 
JF (ІХ) 
«РКОС МЕМШКІТЕ»2 
РОР ЇХ 
FOF ПЕ 
РОР HL 
LI! ОНЬ»Е 
JF (ТХ) 


SPECIALIZING ІМ 


5РӨКАМ IS ADDRESS 
? КЕТОКМ АППКЕ55 


?РОР TWO WORDS OF 
TWO WORDS OF 
ADURESS 
BYTE 


5РОР 
REAL 
ЭКЕАП 


3 RETURN 


RETURN 


? РаКаМ5 


? RETURN 
"пата 


ZEROS 
ZEROS 


VALUE READ UN STACK 
TO CALLER 


со 
202? 


ARE ALDRE 
ADDRESS 


LATA 


WRITE ADDRESS 
%МКІТЕ BYTE 


5КЕТОКМ 


Т0 CALLER — continued on next page— 


QUALITY MICROCOMPUTER HARDWARE 


INDUSTRIAL «+ EDUCATIONAL е SMALL BUSINESS е PERSONAL 
BUILDING BLOCKS FOR MICROCOMPUTER SYSTEMS, CONTROL & TEST EQUIPMENT 


R? I/O 


2K ROM 
2K RAM 


16 K RAM 


| FULLY STATIC 


| MEMORY 
| KIT: $279.00 
WIRED: $310.00 


3 Serial Ports 
1 Parallel Port 
WIRED: $295.00 


ECT-100-F 
RACKMOUNT 
CARD CAGES 
KIT: $200.00 
WIRED: $250.00 


TT-10 

TABLE TOP 
MAINFRAMES 
KIT: $340.00 
WIRED: $395.00 


POWER SUPPLIES, CPU’s, MEMORY, OEM VARIATIONS 763 RAMSEY AVE. 
HILLSIDE, N.J. 07205 


ELECTRONIC CONTROL TECHNOLOGY (201) 686-8080 
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had to use absolute assembly, to be 
certain that the bit patterns which were 
in the file were in fact those which I 
wanted to burn into the EPROM, and I had 
to find a way to ignore the directory 
block, which is 512 bytes long. 

Since I had access to the Cromenco 
Bytesaver board, all I had to do in 
PASCAL was to read the firmware object 
file, throw away the first 512 bytes, 
and then transfer the remaining 1024 
bytes repeatedly into the area of memory 
where the Bytesaver was assigned. That 
would have been easy, but UCSD PASCAL 
had no routines corresponding to BASIC's 
"peek" and "poke"; I had to write them 
also. 

The assembly routines for the 
"peek" and "poke" functions are given 
in Program Listing 1 and correspond to a 
PASCAL FUNCTION ('memread') and a PASCAL 
PROCEDURE ('memwrite'). 


The PASCAL program to burn the 
EPROM is shown in Program Listing 2 and 
should be reasonably easy to read, since 
the variable names are clear. Comments 
in PASCAL are enclosed in curly brackets 
("{" and ")"). All PASCAL keywords are 
written in UPPER case, and all user de- 
fined values are in lower case. 


PROGRAM LISTING 2 
EPROM BURNER PROGRAM 


PROGRAM burns 


ТҮРЕ 
byte = 0..255% 

МАК 
code i РАСКЕП АККАҮГ0..10232 OF bytes 
i» J» addr» count + INTEGERS 


infile $ FILES 


After writing the new firmware and 
assembling it under UCSD, I burned the 
EPROM and plugged it in. The first 
version blew up because I had forgotten 
a POP instruction, and the stack (placed 
in an unused area in refresh memory) 
quickly deteriorated. The second 
version, was also bad, and this time it 
took me a while figure out the reason. 
It seems that SDS had no need for the 
most significant bit of the data coming 
from the computer, so it did not even 
bring it off of the S-100 Bus. I, on 
the other hand, required it in order to 
distinguish between my peculiar random 
cursor addressing functions and normal 
characters. With the line disconnected, 
it floated high, and all characters were 
cursor-control characters. Unfortunate- 
ly, the schematic was wrong in this in- 
Stance, and it was only after I looked 
at the board itself that I discovered 
it. A simple jumper finished the job. 


All in all, the modification was 
not really that difficult, and the 
results are quite pleasing. I would 


not, however, recommend that anyone 
attempt this unless they are well versed 
in both hardware and assembly language 
Software. Тһе firmware is tricky, and 
an understanding of the 5027 controller 
chip is also necessary in order that all 
of the code may be understood. 
Following is the text of the final 
firmware package which I created. 


С DEFINE ASSEMBLY LANGUAGE MODULES AS EXTERNAL 2 


data $ 
INTEGER ) 


PROCEDURE memwrite<( addr y 
FUNCTION memread( addr 4 


BEGIN 

RESETC infiles’ JON СКТ, CODE” 9% 
WRITEC “ENTER LOOF COUNT +“) 
REAL count 9 5 


ІМТЕСЕК)% EXTERNAL» 
+ INTEGERS 


EXTERNAL $ 


С OPEN CODE FILE 7 
€ ASK USER HOW MANY TIMES TO BURN FROM 3 


€ REAL THE SECOND 512 BYTE BLOCK OF THE FILE INTO ‘CODE’ ARRAY 2 


i іс BLOCKRREATD(infilescodes2»125 
addr іс (18 Ж 4096) + (8 Ж 256)? 
€ BURN THE FROM 'COUNT/ TIMES 2 
FOR i = 1 TO count ПО BEGIN 
ИКТТЕ! МС“ STARTING FASS 7,19% 
ЕОК 4 0 TO 1023 10 
memwritet(addrtüscodeL.) 
ЕМІ» 
< СНЕСК ТНЕ РКОМ 2 
FOR i іс 0 TO 1023 ПО 
IF (memreac( addr + 1) <> 
WRITELN(C^ATDTIRESS ^»si»^ 
ENI!, 


+. 
өш 


codeli > 
IS ‘smemreasd( addr + i dy’ 


С BYTESAVER ADDRESS > 


THEN 


BUT SHOULD RE 'scodeLilo)s 


continued on page 52 
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North Star Horizon- 


COMPUTER WITH CLASS 


The North Star Horizon computer can be found everywhere 
computers are used: business, engineering, home — even the 
classroom. Low cost, performance, reliability and software 
availability are the obvious reasons for Horizon's popularity. 
But, when a college bookstore orders our BASIC manuals, 

we know we have done the job from A to Z. 


Don't take our word for it. Read what these instructors have to 
say about the North Star Horizon: 
"We bought a Horizon not only for its reliability record, 
but also because the North Star diskette format is the industry 
standard for software exchange. The Horizon is the first computer 
we have bought that came on-line as soon as we plugged it in, 
and it has been running ever since!" 
— Melvin Davidson, Western Washington University, 
Bellingham, Washington 
"After | gave a Уг hour demonstration of the Horizon 
to our students, the sign-ups for next term's class in BASIC 
jumped from 18 to 72." 
— Harold Nay, Pleasant Hill HS, Pleasant Hill, California 


"With our Horizon we brought 130 kids from knowing 
nothing about computers to the point of writing their own Pascal 
programs. | also use it to keep track of over 900 student files, 
including a weekly updated report card and attendance figures." 

— Armando Picciotto, Kennedy HS, Richmond, California 


"The Horizon is the best computer | could find for my class. 
It has an almost unlimited amount of software to choose from. 
And the dual diskette drives mean that we don't have to waste 
valuable classroom time loading programs, as with computers 
using cassette drives." 
— Gary Montante, Ygnacio Valley HS, Walnut Creek, Calif. 


See the Horizon at your local North Star dealer. 


y) m 
Z 


North Star Computers 

1440 Fourth Street 

Berkeley, Ca 94710 

(415) 527-6950 TWX/TELEX 910-366-7001 


COMPUTERIZED 
BULLETIN BOARD 
SYSTEMS 


by 


Russell Gorr 


A complete and up-to-date listing of CBBS facilities 


across the country. 


Over the past few years, the number 
of computer hobbyists who have modems 
has increased dramatically. Іп the past 
year alone, бопе computer clubs show ап 
increase in modems of four to six times 
the number of the previous year. The 
increased number of modems on systems 
has also caused a proliferation of 
Computerized Bulletion Board Systems 
throughout the Personal Computing 
community. 

The Computerized Bulletin Board 
System, or CBBS, acts as a clearinghouse 
for information of interest to Personal 
Computing users. Typical messages left 
on the system include messages of items 
for sale, people looking for help with 
hardware or software, people looking for 
others with the same type of equipment 
or applications, rumors and messages to 
others. Also, a few clubs have put 
their newsletters on the CBBS for dis- 
tribution before the printed material is 
ready. 

Most CBBS's are similar іп 
operation, since most have gotten their 
software from the same source and thus 
they have only minor differences between 
them. Most run CP/M similar to the 
Chicago CBBS operated by Ward Cristensen 
and Randy Suess. Most are compatible 
with terminals running at 300 baud, RS- 
232C, while some can also handle other 
baud rates (the other most common being 
110 baud). Usually the hard part is to 
get through to the system. Most systems 
are readily accessible after 11PM (the 
rates are cheaper then also). When you 
get the dial tone, engage your machine 
and hit a few carriage returns. From 
there most systems are self-prompting. 

As mentioned earlier, the Chicago 
CBBS was created by Ward and Randy for 
members of the Chicago Area Computer 
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Also a summary of how to access them. 


Hobbyist Exchange club to use. Access 
to the system is via 110 or 300 baud 
ASCII terminal at 312-528-7141. When 
you get the tone, press return several 
times for CBBS to detect your terminal 
speed. 

Another club with a CBBS is the New 
England Computer Society. Their CBBS is 
located in Cambridge Massachusetts. 
They are using the standard CBBS CP/M 
software from Ward and Randy. The CBBS 
runs at 110 or 300 baud. Just hit a few 
returns once you are on for CBBS to 
detect your speed. A summary of the 
Cambridge CCBS commands are as follows: 


-CBBS COMMAND SUMMARY- 


eturn - Command List 
Command Summary 
Print Bulletins 
Case Switch 
Half/Full Duplex Switch 
Enter Message 
Edit commands are: 
- Abort 
- Continue Input 
- Edit Line 
Help 
List Lines 
Retype Line 
- Save Message 
Goodbye (logoff) 
Helpful Information 
Kill (delete) message 
Set (0-9) Null Fill Characters 
Quick Summary of Messages 
Retrieve Messages 
Summarize Messages 
Search Parameters: 
field = string 
Where fields are: 
F = From 
T = To 


R 
? 
B 
с 
р 
Е 


uo 
сг: юмс» 
ІІІ 


о пюог2хщо 
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S = Subject 

D = Date 
W = Print Welcome Text 
X = Expert mode 

-CBBS CONTROL CHARACTERS- 
DEL/B/ = Deletes the previous character 
typed 

Cntrl-U Deletes the current line 


Cntrl-R = Retypes the current line 

Cntrl-S - Pauses the output (any 
character to restart) 

Cntrl-C = Throws away current printing 

Cntrl-K = Abort function and return to 
command 


The command summary of the 
Cambridge CBBS is similar to most that 
are running CP/M. Some CBBS's have 
variations of the letter codes, some 
have more functions while others have a 
few less (the Akron Ohio CBBS for 
example does not have the Cntrl-C or 
Cntrl-K functions). 

Since the CBBS's are using RS-232C 
ASCII, it is easy to access systems in 
your area that are not of your computer 
type. You can call up an Apple 
Bulleting Board or a Forum-80 and also 
get your messages onto and from those 
Systems. The commands are similar, but 
will probably have different letter 


codes than those shown above. The 
number of ABBS (Apple Bulletin Board 
System) and Forum-80 (TRS-80 Bulletin 
Board System) is growing in number 
rapidly as is the CP/M CBBS's. 

Some other CBBS's offer other fea- 
tures as well as being clearinghouses. 
A few of the Forum-80 systems have 
dedicated uses. The Family Historian 
Forum is an "electronic newsletter for 
the sharing of research problems, 
suggestions and messages for geneolists 
across the nation". The Engineer-80 is 
dedicated to dissemination of engineer- 
ing related applications for micro- 
computers. The Memphis Forum-80 handles 
information on handicapped applications 
for microcomputers. 

One group in the Washington DC area 
is AMRAD. Their CBBS is accessible via 
telephone (703-281-2125) or via an 
amateur radio repeater in McLean, 
Viginia. Radio access is via the WR4APC 
2 meter repeater on 147.81/147.21 MHz. 
The computer recognizes the call WR4IWG 
when sent using 45 baud (60 wpm) Baudot 
RTTY with tones of 2125 Hz (mark) and 
2295 Hz (space). When calling the CBBS, 
the baud rates are 110 or 300 baud. 
Other computer clubs are also in the 
planning stages of telephone/repeater 
set-ups. The South Florida Computer 
Club is planning a repeater link in the 
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OBSCURE AND DIRTY 
PROGRAMMING TRICK 


Bill Fuller 
Computer Hobbyist Group of North Texas 


Ever gotten ready to call some 
subroutine and found that the argument 
you needed to send it in the A-register 
was in the B-register because of some 
previous calculation? And to make 
things worse you do not have another 
free register to use to make the swap. 
So you are forced to make the slow route 
through main memory to do this data 
shuf fle? 


before operation 


Maybe this hasn't happened to you 
but you might find this technique enter- 
taining. It trades the contents of A 
and B without the need of any other 
intermediate storage location. Accord- 
ing to Bill Fuller this is analogous to 
Swapping the contents of a bucket of 
black paint and a bucket of white paint 
without mixing them. But somehow it 
works. I will demonstrate by example. 


after operation 


register-A register-B register-A register-B 


@onset 11010010 11100101 same 

А-В В 11010010 11100101 11010010 00110111 
А-М-В->А 11010010 00110111 11100101 00110111 
A¥-B->B 11100101 00110111 11100101 11010010 
where № = the Exclusive-OR operation. 
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ТНЕ ІМРОКТАМСЕ ОҒ ТНЕ 
IEEE 58-100 STANDARD 


by Sol Libes 


The IEEE S-100 Standard will soon be adopted. What 
is the significance of this document? 


There are currently close to two 
dozen different manufacturers of 5-100 
mainframes and 50 manufacturers of over 
400 S-100 plug-in boards. This makes 
the 5-100 bus far and away the most 
popular computer bus system in current 
use. Further, it is increasing in pop- 
ularity. Last year five new S-100 
mainframes were introduced despite the 
fact that three S-100 manufacturers went 
out of business. Their demise however 
was due to poor management and not a 
lack of orders. 


The fact is that a bus oriented 
System offers more power and flexibility 
than integrated systems such as the TRS- 
80, PET and APPLE. Опе example of this 
power is the fact that an S-100 system 
user can select from seven different 8- 
bit CPU boards (8080, 8085, 8088, 780, 
6502, 6800 and 6809) and five different 
16-bit CPU boards (9900, LSI-11, 8086, 
28000 and Pascal Microengine). 


However, the 5-100 bus, created by 
MITS in 1975, was only very loosely 
defined by MITS and many S-100 suppliers 
changed pin assignments and employed 
different timing, drive and loading 
circuits. The result was that many S- 
100 boards claimed by their suppliers to 
Бе S-100:compatible would work in some 
5-100 systems but not in others. Тһе 
new IEEE S-100 Standard should eliminate 
this problem. However, a word of 
caution is necessary here. The S-100 
Standard has been in circulation for 
about a year in proposal form. бопе S- 
100 suppliers have already introduced S- 
100 products which the manufacturers 
claim to be "IEEE S-100 compatible" and 
are in fact compatible with an early 
version of the proposed standard. Some 
other suppliers have introduced boards 


compatible with the later version of the 
proposed standard which is reprinted 
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here. Іп the case of the latter there 
is little liklihood of compatibility 
problems. However, in the former there 
could be problems. Once the standard 
is formely adopted (hopefully by May) 
this problem should dissappear. 


Secondly, we are moving into a new 
era of more powerful microcomputer 
Systems. Things MITS did not even 
envision, when they created the bus. 
Things like expanding direct memory 
addressing beyond 64K bytes and multi- 
processors on the bus. Тһе new IEEE 5- 
100 standard thus defines these new more 
powerful applications. It expands 
memory addressing to 16 megabytes and 
I/O addressing to 64K ports. It expands 
the vectored interrupt system to 11 
inputs and provides for up to 16 masters 
on the bus. 

This means that the new IEEE S-100 
bus is far and away the most powerful 
microcomputer bus architecture avail- 
able. The IEEE standard sets the 
foundation for even greater use and 
popularity of the bus, so that it will 
continue to maintain its dominance for 
many years to come. 


I wish to thank Dr. Robert G. 
Stewart, Chairman of the IEEE-CS 
Computer Standards Committee, George 
Morrow of Thinker Toys and Tru Seaborn, 
editor of IEEE Computer magazine for 
their assistance in bringing this 
reprint to 5-100 MICROSYSTEMS. 


One last caution. The following is 
Still a proposal. At this point it 
appears to be very close to what will 
actually be adopted. However, it is 
possible that there may be some minor 
changes (e.g. a pin assignment). As 
Soon as the standard is adopted S-100 
MICROSYSTEMS will print the revised 
standard or the changes. 
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This proposed standard eliminates many of the problems іп the 
S-100 bus and upgrades it for 16-bit microprocessors. It is 
offered here for public comment before submission to the 

IEEE Standards Board. 
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Introductory comments by 
Robert G. Stewart, Chairman, 
IEEE-CS Computer Standards Committee 


The following draft of a proposed standard for the 
S-100 bus is the culmination of over a year and a half 
of effort to eliminate many of the bus’s problems and 
to upgrade it to be suitable for 16-bit microproces- 
sors. The address bus has been extended to 24 bits, 
the data in and data out buses ganged to forma 16-bit 
wide data bus for 16-bit transactions, and two addi- 
tional handshaking lines added to permit intermixing 
of 8- and 16-bit memory cards. 

A binary encoded multiple master arbitration bus 
permits up to 16 masters on the bus. The necessary 
logic can be implemented in one chip. Additional 
ground lines, a power fail line, and an error line have 
been added. Three lines termed NDEF—for not to be 
defined—have been allotted to allow leeway to im- 
plementers for specialized use. Such use must be 
specified in all literature. Five lines are RFU—re- 
served for future use. Some lines formerly used for 
front panel purposes have been deleted, with the in- 
tention that such lines can best be handled by a 
jumper cable from the CPU card to the front panel. A 
DMA protocol is specified which provides overlap of 
the control lines at the beginning and end of the tran- 
sition between permanent and temporary masters. 
This allows the address, data, and control buses to 
settle before information is transferred. 

As a bit of personal testimony, I implemented the 
new DMA protocol on my own system, which in- 
cludes a Digital Systems dual floppy disk interfaced 
toa MITS Altair 8800, using DMA for disk transfers. 
The soft error rate, presumably due to glitching on 
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the positive true logic lines, dropped from a situation 
where a file would be seriously munged in a few hours 
to the present situation where I can work for days on 
end without an observable error. 

We haveobserved a new typographic convention in 
publishing the proposed standard. The use of an over- 
bar to denote electrically low active or negative true 
logic lines has been replaced by a postfix asterisk to 
avoid confusion with Boolean negation and permit 
typing on word processing systems. This is verbal- 
ized by the word ‘‘star,” replacing the prior word 
“bar.” The Boolean negation overbar can be optional- 
ly replaced by a prefix minus sign, with parentheses if 
needed. 

The named authors of the standard were evenly 
divided as to whether the asterisk should be included 
in logic equations and state diagrams as well as in 
electrical signal names and timing diagrams. Two 
authors believe that the asterisk, when thought of as 
a designator rather than as the negation operator, 
adds clarity and consistency, and lessens the need to 
remember or look up the electrically active level when 
converting from logic to electrical representations. 
Such use makes logic state diagrams more directly 
useful for interpreting oscilloscope or logic analyzer 
waveforms. 

The other two authors feel that the inclusion of the 
asterisk in the name of a logic state or variable is like- 
ly to carry with it the implication of logical negation, 
thus causing the logic statements to be interpreted 
incorrectly. Furthermore, they assert that many de- 
signers think mostly in terms of electricallevels, with 
high being true, which again causes logic statements 
to beinterpreted incorrectly. Тһеу propose to resolve 
this hazard by removing the electrical information, 
1.е., theasterisk, from the variable name when it is us- 


0018-9162/79/0700-0028$00.75 € 1979 IEEE 


20 


ed in a logic context as opposed to an electrical ог tim- 
ing context. 

A compromise has been reached where the asterisk 
is not used in the context of logic equations, but is in- 
cluded elsewhere in the document. We solicit feed- 
back from the readers on these two points of view. 

The S-100 bus subcommittee has been ably chaired 
by George Morrow and Howard Fullmer. Both of 
them provided invaluable technical insights which 
have been incorporated throughout the draft stan- 
dard. John Walker of Marinchip Systems suggested 
the method of using 16-bit memory and interface 
cards interchangeably with 8-bit cards. David 
Gustavson and Leo Paffrath of SLAC suggested the 
bus arbitration scheme which has also been im- 
plemented on the Department of Energy’s Fastbus. 
Howard Fullmer suggested the DMA overlap pro- 
tocol which lowers glitching noise. Kells Elmquist of 
InterSystems offered a critique of the draft pub- 
lished in May 1978 in Computer and provided many 
useful suggestions for improvement. He carefully in- 
vestigated numerous timing and electrical alterna- 
tives and resolved many open questions relating to 
the standard. Kells wrote the final version of the draft 
for submission to and revision by the subcommittee. 

The IEEE Computer Society is publishing this 
standard in draft form to allow you to comment upon 
it prior to submission to the IEEE Standards Board 
for adoption as an IEEE standard. For example, 
should the data bus be extended to 32 bits, and if so, 
how? Your comments should be sent to George Mor- 
row by August 15, 1979, with copies to Gordon Force. 
Mr. Morrow’s address is: 


George Morrow 
Thinker Toys 
5221 Central Avenue 
Richmond, California 94804 


If you would like to participate in other standard- 
ization efforts of the Microprocessor Standards Com- 
mittee, please contact its chairman: 


Gordon Force 
Logical Solutions 
1128 Amur Creek Court 
San Jose, California 95051 


Finally, preparation of this proposed standard has 
benefited from the contributions of many individuals 
and companies. We indeed thank them all. li 


The proposed standard 
1.0 General 
1.1 Scope 


This standard applies to interface systems for com- 
puter system components interconnected via a 100- 
line parallel backplane commonly known as the S-100 
bus. 

It applies to microprocessor computer systems, or 
portions of them, where 
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1) Data exchanged among the interconnected 
devices is digital (as distinct from analog). 

2) The total number of interconnected devices is 
small (22 or fewer). 

3) Thetotal transmission path length among inter- 
connected devices is electrically short (25" or 
less). That is, transmission line propagation 
delays are rot important. 

4) The maximum data rate of any signal on the bus 
is low (less than or equal to 6 MHz). 


1.2 Object 


'This standard is intended: 


1) To define a rational, general-purpose interface 
system for designers of new computer system 
components that will ensure their compatibility 
with present and future S-100 computer 
systems. 

To providethe microprocessor computer system 

user with compatible device families which will 

communicate in an unambiguous way without 
modification, from which a modularly expand- 
able computer system may be constructed. 

3) To enable the interconnection of independently 
manufactured devices into a single system. 

4) To specify terminology and definitions related 
to the system. 

5) Todefinea system with the minimum number of 
restrictions on the performance characteristics 
of devices connected to the system. 

6) To define a system that, of itself, is of relatively 
low cost, and allows the interconnection of low 
cost devices. 

7) To define a system that is easy to use. 


2 


1.3 Definitions 


The following definitions apply for the purpose of 
this standard. This section contains only general 
definitions. Detailed definitions are given in other 
sections as appropriate. 


1.3.1 General system terms 


Compatibility. The degree to which devices may be 
interconnected and used without modification, when 
designed as defined in Sections 2, 3, and 4 of this 
standard. 

Interface. А shared boundary between parts of a 
computer system, through which information is con- 
veyed. 

Interface system. Тһе device independent func- 
tional, electrical, and mechanical elements of an inter- 
face necessary to effect unambiguous communica- 
tion among a set of devices. Driver and receiver cir- 
cuits, signal line descriptions, timing and control con- 
ventions, message transfer protocols, and functional 
logic circuits are typical interface system elements. 
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System. А set of interconnected elements con- 
stituted to achieve a given objective by performing 
specified functions. 


1.3.2 Signals and paths 


Assert. 'To drive a signal line to the true state. The 
true state is either a high or low state, as specified for 
each signal. 

Bidirectional bus. A bus used by any individual 
device, or set of devices, for the two-way transmis- 
sion of messages, that is, both input and output. 

Bit-parallel. A set of concurrent data bits present 
on alike number of signal lines used to carry informa- 
tion. Bit-parallel data bits may be acted upon concur- 
rently as a group or independently as individual data 
bits. 

Bus. A set of signal lines used by an interface 
system, to which a number of devices are connected, 
and over which messages are carried. 

Byte. A set of bit-parallel signals corresponding to 
binary digits operated on as a unit. Connotes a group 
of eight bits where the most significant bit carries the 
subscript 7 and the least significant bit carries the 
subscript 0. 

Byte-serial. A sequence of bit-parallel data bytes 
used to carry information over a common bus. 

High state. 'The electrically more positive signal 
level used to assert a specific message content 
associated with one of two binary logic states. 

Low state. The electrically less positive signal level 
used to assert a specific message content associated 
with one of two binary logic states. 

Signal. The physical representation which conveys 
data from one point to another. For the purpose of 
this standard, this applies to digital electrical signals 
only. 

Signal level. The magnitude of a signal when con- 
sidered in relation to an arbitrary reference 
magnitude (voltage in the case of this standard). 

Signal line. One of a set of signal conductors in an 
interface system used to transfer messages among in- 
terconnected devices. 

Signal parameter. That parameter of an electrical 
quantity whose values or sequence of values convey 
information. 

Unidirectional bus. A bus used by a device for one- 
way transmission of messages, that is, either input 
only or output only. 

Word. A set of bit-parallel signals corresponding to 
binary digits and operated on as a unit. Usually con- 
notes a group of 16 bits where the most significant bit 
carries the subscript 15 and the least significant bit 
carries the subscript 0. 


1.4 State diagram notation 


Each state that an interface function can assume is 
represented graphically by a circle. A mnemonic is 
used within the circle to identify the state. 

АП permissible transitions between states of an in- 
terface function are represented graphically by ar- 
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rows between them. Each transition between states 
may be qualified by an expression whose value must 
be either true or false. If a state transition is not 
qualified by an expression it is assumed that transi- 
tion from one state to another will occur after a mini- 
mum time period, as indicated in the timing specifica- 
tions. An interface function must enter the state 
pointed to if and only if the driving expression 
becomes true, or in the case of a time dependent tran- 
sition, as soon as the minimum specified time has 
passed. 


EXPRESSION 1 


EXPRESSION 2 


An expression consists of two parts, a driving ex- 
pression and a driven expression, separated by a 
slash (/). The driving expression is mandatory and 
specifies the conditions necessary for the state tran- 
sition. The driven expression is optional and is used 
to indicate signal transitions as a result of the state 
transition. A signal transition is indicated by the 
signal name followed by an equal sign (—), followed 
by an indication of the state attained by the signal as 
a result of the transition. A driving expression con- 
sists of one or more messages used in conjunction 
with the operators AND (а,Ь), OR (a+b), and NOT 
(—а). Precedence is defined by parentheses. An exam- 
ple expression is: (driving/driven) 


А“ (B+C) / D=F(ALSE), E=T(RUE) 


If A AND (B OR C)is true, then Dis forced false and E 
is forced true, and the state transition takes place. 


1.5 Logical and electrical state relationships 


This standard makes a distinction between the 
logical function of a signal and its electrical im- 
plementation. All equations in this standard are logic 
equations, not electrical equations (unless otherwise 
stated), and are written in terms of logic states. The 
use of the term “асбіуе” for the purpose of this stan- 
dard is synonymous with the logic state true. 

There are two types of electrical implementation of 
the logic states: 


Active high signals. Active high signals are 
represented without a suffix after the signal name 
mnemonic (i.e. ABCD). 


BINARY ELECTRICAL ELECTRICAL 
LOGIC STATE ТАТЕ SIGNAL LEVEL STATE 
CORRESPONDS TO 
FALSE (F) 0 <.8 V, CALLED THE L 
LOW STATE. 
CORRESPONDS TO 
TRUE (T) 1 22.0 V, CALLED THE H 
HIGH STATE. 
COMPUTER 


Active low signals. Active low signals аге 
represented with an asterisk suffix after the 
mnemonic (i.e. ABCD*). 


BINARY ELECTRICAL ELECTRICAL 
LOGIC STATE STATE SIGNAL LEVEL STATE 
CORRESPONDS TO 
FALSE (F) 0 22.0 V, CALLED H 
THE HIGH STATE. 
CORRESPONDS TO 
TRUE (T) i <.8 V, CALLED L 


THE LOW STATE. 


Intranslating a logic equation into an electrical im- 
plementation, care must be taken to account for the 
active-high or active-low character of the electrical 
signal. For example, the logic equation 


MWRT = pWR • —sOUT, (logic equation) 
when implemented electrically, becomes 
MWRT = (—-pWR*) * —sOUT, (electrical equation) 


since pWR* is the electrical signal carrying the pWR 
information on the bus. 
Note that this is equivalent to 


MWRT = —(pWR* + sOUT), (electrical equation) 


by deMorgan’s theorem; consequently, a single two- 
input NOR gate is sufficient to implement MWRT, if 
it meets the loading and drive requirements. 

The edge or change of electrical value of an elec- 
trical signal on a timing diagram which causes a tran- 
sition change of the variable as a logic variable from 
false to true is: 


Signal Edge 
active high rising 
active low falling 


Logic equations in state diagrams are written in 
terms of logic state, not electrical state. 

The suffix asterisk ‘‘*’’ is not a negation operator. 
It is a designator (like a comment or footnote) at- 
tached toa name, telling the reader what the relation- 
ship is between the truth state and the electrical 
state. That is, this variable is true when the line on the 
bus is low. 

A prefix minus sign “--” represents the logical 
negation operator and is equivalent to the use of an 
overbar. Parentheses are used to enclose the negated 
variable when required for clarity. 


” 


1.6 Interface system overview 
1.6.1 Interface system objective 

The overall purpose of the interface system is to 
provide an effective communication link over which 
messages are carried in an unambiguous way among 


a group of interconnected devices. 
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Messages in an interface system belong to either of 
two broad categories: 


1) Messages used to manage the interface system 
itself, called interface messages. 

2) Messages used by the devices interconnected by 
the interface system, and carried by that sys- 
tem, but not part of the interface system itself 
(i.e. data). These are called device dependent 
messages. 


The interface system herein described comprises 
the necessary functional and electrical specifications 
for interface messages to effect the objective of this 
standard, but it is beyond the scope of this standard 
to specify the nature or meaning (other than electrical 
signal level) of device dependent messages. 


1.6.2 Fundamental communication capabuities 


An effective communication link requires two basic 
functional elements to organize and manage the flow 
of information among devices: 


1) A device acting as a bus master. 
2) A device acting as a bus slave. 


All data transfer communications between a bus 
master and a bus slave are carried out in terms of a 
generalized bus cycle generated by the bus master 
and responded to by the addressed bus slave. 

In the context of the interface system described by 
this standard: 


1) A device acting as a bus master has the capabili- 
ty to address all bus slaves, or some portion of 
them, by generating all interface messages nec- 
essary to effect a bus cycle, and has the capabil- 
ity to transfer device dependent messages to or 
from the addressed slave as a part of that bus cy- 
cle. 

2) A device acting as a bus slave monitors all bus 
cycles, and has the capability, thus, to be ad- 
dressed by the bus master and to transfer device 
dependent messages to or from the bus master. 


Bus master and bus slave capabilities occur both 
individually and collectively in devices intercon- 
nected via the S-100 interface system. 


1.6.3 Message paths and bus structure 


The S-100 interface system consists of a set of 
signal lines used to carry all information, interface 
messages and device dependent messages among in- 
terconnected devices. 

The bus structure is organized into eight sets of 
signal lines: 


1) Data bus— 

2) Address bus— 

3) Status bus— 

4) Control output bus— 
5) Control input bus— 


16 signal lines. 

16 or 24 signal lines. 
8 signal lines. 

5 signal lines. 

6 signal lines. 


6) DMA control bus— 8 signal lines. 
7) Vectored interrupt bus— 8 signal lines. 
8) Utility bus— 20 signal lines. 
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2.0 Functional specification 
2.1 Functional partition 


Functional devices interconnected via the interface 
system are divided into two broad classifications, bus 
masters and bus slaves, according to their relation- 
ship to the generation and reception of interface 
messages. 

Devices acting as bus masters are responsible for 
the initiation of all bus cycles, and for the generation 
of all signals necessary for the conduction of an unam- 
biguous bus cycle. These signals are termed type M 
signals, and consist of the address, status, and con- 
trol buses. Device dependent messages are transmit- 
ted and received on the data bus. 

Bus masters are subdivided into two classifica- 
tions, permanent masters and temporary masters. A 
permanent bus master (generally a CPU) is the high- 
est priority master in the interface system. A tem- 
porary master may request the bus from the perma- 
nent master for an arbitrary number of bus cycles, 
and then returns control of the bus to the permanent 
master. The transfer of bus control from a permanent 
master to a temporary master and back to the perma- 
nent master is termed a DMA cycle. 

Тһе difference between a permanent bus master 
and a temporary bus master is that: 


1) Only one permanent master may exist within 
the interface system, whereas up to 16 tempo- 
rary masters may co-exist in a single system. 

2) Atemporary master is not subject toa DMA cy- 
cle, that is, there are no nested ОМА operations. 


Devices acting as bus slaves are bus cycle recep- 
tors. A bus slave monitors all bus cycles and, if ad- 
dressed during a particular bus cycle, accepts or 
sends the requested device dependent message on 
the data lines. While bus masters must generate a 
specific set of signals in order to assure an unam- 
biguous bus cycle, a bus slave need only examine and 
generate that subset of bus signals necessary to com- 
municate with bus masters. 


2.2 Signal lines 
2.2.1 General 


The bus is a collection of message paths defined 
relative to the current bus mastèr. They аге: 


1) Address bus. 

2) Status bus. 

3) Data input/output bus, 
4) Control output bus. 

5) Control input bus. 

6) DMA control bus. 

7) Vectored interrupt bus. 
8) Utility bus. 


The nature and use of each bus is specified in the 
following sections. 
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2.2.2 Address bus 


The address bus consists of 16 or 24 bit-parallel 
signal lines used to select a specific location in 
memory or a specific input/output device for com- 
munication during the current bus cycle. 

All bus masters must assert at least 16 address 
bits, but may assert 24 address bits if extended ad- 
dress capability is desired. Validity of the address 
bus is defined in 2.7.3. 

Table 1 summarizes address usage for various bus 
cycles. 


Table 1. 
Address usage for different bus cycles. 
STANDARD EXTENDED 
OVE TEE ADDRESSING ADDRESSING 
MEMORY READ 
MEMORY WRITE А0-А15 А0-А23 
M1 (0Р-СОПЕ FETCH) 
INPUT 
OUTPUT СЕ A0-A15 
INTERRUPT ACKNOWLEDGE NONE NONE 
HALT ACKNOWLEDGE NONE NONE 
T see 2.2.2.3 


2.2.2.1 Standard memory addressing 


The standard memory address bus consists of 16 
lines specifying 1 of 64K memory locations. These 16 
lines are named A0 through A15, where A15 is the 
most significant bit. 


2.2.2.2 Extended memory addressing 


Тһе extended memory address bus consists of 24 
lines specifying 1 of 16 million memory locations. 
These 24 lines are named A0 through A23, where A23 
is the most significant bit. 


2.2.2.8 Standard input/output device addressing 


The standard I/O device address bus consists of 8 
lines, A0 through A7, specifying 1 of 256 I/O devices. 
АТ is the most significant bit. 

NOTE: The I/O device address has traditionally 
been duplicated onto the high order address byte, 
A15-A8. While this is considered acceptable pro- 
cedure, it is not recommended for new designs as it 
complicates expansion to extended I/O device ad- 
dressing. 


2.2.2.4 Extended input/output device addressing 
Тһе extended I/O device address bus consists of 16 
lines, A0 through A15, specifying 1 of 64K devices. 
A15 is the most significant bit. 
2.2.3 Status bus 
The status bus consists of eight lines which iden- 
tify the nature of the bus cycle in progress, and 
qualify the nature of the address on the address bus. 
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Тһе mnemonics for status lines always begin with a 
lower-case s. 
The 8 status lines are: 


1) Memory read— sMEMR. 
2) Op-code fetch— sM1. 

3) Input— sINP. 

4) Output— sOUT. 
5) Write cycle— sWO*. 
6) Interrupt acknowledge— sINTA. 
7) Halt acknowledge— sHLTA. 


8) Sixteen-bit data transfer request— sXTRQ*. 


The 8 lines on the status bus must be generated by 
the current bus master. 
Validity of the status bus is given in 2.7.3. 


2.2.3.1 Status memory write 


One relevant status signal is not directly available 
on the bus, but may be created by the combination of 
two others. Status Memory Write is defined as: 


sMemory Write = 
(—sOUT) - sWO, (logic equation) 


that is, status memory write is true when sOUT is 
false and sWO (write) is true. 


2.2.3.2 Status usage chart 


Table 2 gives the status word definition for all 
possible bus cycles. (W) refers to word (16-bit data 
path) operations; (B) refers to byte (8-bit data path) 
operations. H=high state. L=low state. X=don’t 
care. 


Table 2. 
Status usage chart. 
a * 
> ж = < < e 
шт оэ P Ты 
STATUS BITS 222922515 
CYCLE TYPE 
MEMORY READ (B H L H L L L L H 
М) ніні L L L L 
OP-CODE FETCH (8) H H H E L bL L H 
wW H H H L L L L L 
MEMORY WRITE (By E. b b Lb E E Lb H 
(W L L L L L L L L 
OUTPUT (B) L L L H L L L H 
w EL L L H L & EG L 
INPUT (B L L нін L L HH 
М) L L H LH L L L 
INTERRUPT (B L X H L L H L H 
ACKNOWLEDGE (W) L X H L L H L L 
HALT ACKNOWLEDGE X X H L E L H X 
WHERE: 
Н = HIGH STATE 
L = LOW STATE 
X = DON'T CARE 
W = 16-BIT OPERATION 
В = 8-ВІТ OPERATION 
2.2.4 Data bus 


Data input and data output are always specified 
relative to the current bus master. Data transmitted 
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by the current bus master toa bus slave is called data 
output. Data received by the current bus master from 
a bus slave is called data input. 

The data bus consists of 16 lines grouped as two 
unidirectional 8-bit buses for byte operations and asa 
single bidirectional bus for 16-bit word operations. 


2.2.4.1 Byte operations 
Two unidirectional 8-bit buses are used for byte 


data transfers. Data output appears on the data out- 
put bus (000-007), where ПО? is the most signifi- 


сап bit. 


Data input appears on the data input bus 
(DIO-DI7), where DI7 is the most significant bit. 


2.2.4.2 Word operations 


For 16-bit data transfers the DI and the DO buses 
are ganged together, creating a single 16-bit bidirec- 
tional bus. T'wo signallines control the ganging of the 
data buses, sixteen request (sXTRQ*) and sixteen 
acknowledge (SIXTN*). When both of these lines are 
true (in the low state), the data buses are ganged with 
DOO corresponding to DATA 0 and DI7 corre- 
sponding to DATA 15, the most significant bit. 

Complete specification of the 8/16-bit protocol is 
given in 2.6. 


2.2.5 Control output bus 


The 5 lines of the control output bus determine the 
timing and movement of data during any bus cycle. 
The mnemonics for the control output lines always 
begin with a lower-case p. 

Тһе five lines are: 


1) pSYNC, which indicates the start of a new bus 
cycle. 

2) pSTVAL*, which in conjunction with pSYNC 
indicates that stable address and status may be 
sampled from the bus in the current cycle. 

3) pDBIN, a generalized read strobe that gates 
data from an addressed slave onto the data bus. 

4) pWR*, a generalized write strobe that writes 
data from the data bus into an addressed slave. 

5) pHLDA, the hold acknowledge signal that in- 
dicates tothe highest priority temporary master 
that the permanent master is relinquishing con- 
trol of the bus. 


The control output signals are subject to the func- 
tional and timing disciplines given in 2.7, 3.8, and 3.9. 


2.2.6 Control input bus 


The six lines of the control input bus allow bus 
slaves to synchronize the operations of bus masters 
with conditions internal to the bus slave (e.g., data 
not ready), and to request operations of the perma- 
nent master (e.g., interrupt or hold). 

The six control input lines are: 


1) RDY 
2) XRDY 
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3) INT* 
4) NMI* 
5) HOLD* 
6) SIXTN* 


2.2.6.1 Ready lines 


The ready lines are used by bus slaves to syn- 
chronize bus masters to the response speed of the 
slave. Thus cycles are suspended and wait states in- 
serted until both ready lines are asserted. 

The RDY line is the general ready line for bus 
slaves. It is specified as an open collector line. 

The XRDY line is a special ready line commonly 
used by front panel devices to stop and single step 
bus masters. As it is not specified as an open collector 
line, it should not be used by other bus slaves, since a 
bus conflict may exist. 


2.2.6.2 Interrupt lines 


Тһе two interrupt lines, INT* and NMI*, are used 
to request service from the permanent bus master. 

The INT* line may be masked off by the bus 
master, usually via an internal software operation. If 
the master accepts the interrupt request on Ше INT* 
line, it may respond with an interrupt acknowledge 
bus cycle, accepting vectoring information from the 
data bus. The INT* line is often implemented as a 
"group interrupt" line in conjunction with the vec- 
tored interrupt bus. In this case, INT* indicates the 
presence of one or more vectored interrupt requests. 

The NMI* line is a non-maskable interrupt request 
line, that is, it may not be masked off by the bus 
master. Accepting an interrupt on the NMI* line 
need not generate an interrupt acknowledge bus cy- 
cle. 

Aninterrupt request on the INT* lineis asserted as 
a level, that is, the line is asserted until interrupt ser- 
vice is received. An interrupt request on the NMI* 
line, on theother hand, is asserted as a negative going 
edge, since no interrupt acknowledge cycle need be 
generated. 

Both these lines are specified as open collector 
lines. | 


2.2.6.3 Hold request 


The hold request line, HOLD*, is used by tem- 
porary bus masters to request control of the bus from 
the permanent bus master. The HOLD* line may be 
masked by the permanent bus master to prevent tem- 
porary masters from gaining bus control. 

The HOLD* line is specified as an open collector 
line, and may only be asserted at certain times. See 
2.8.3. 


2.2.6.4 Sixteen acknowledge 


The sixteen acknowledge line SIXTN*, is a 
response to the status signal sixteen request 
(sX TRQ*), and indicates that the requested 16-bit 
data transfer is possible. 
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The SIXTN* line is specified as an open collector 
line. Detailed specification of the use of this line is 
given in 2.6. 


2.2.7 DMA control bus 


The eight lines of the DMA control bus are used in 
conjunction with control bus signals HOLD* and 
pHLDA. They arbitrate among simultaneous re- 
quests for control of the bus by temporary masters 
and disable the signal drivers of the permanent bus 
master, thus effecting an orderly transfer of bus con- 
trol. 

Alleight lines of the DMA control bus are specified 
as open collector lines. 

Тһе eight DMA control lines are: 


1) DMAO* 
2) DMAI* 
3) DMA2* 
4) DMA3* 
5) ADSB* 
6) DODSB* 
7) SDSB* 
8) CDSB* 


Detailed specification of the use of these lines is 
given in 2.8. 


2.2.7.1 DMA arbitration 


Тһе four lines that arbitrate among simultaneous 
requests for bus control by temporary masters are 
DMAO* through DMA3*. The encoded priority of 
requesters is asserted on these lines and, after set- 
tling, they contain the priority number of the highest 
priority requester. 

Detailed specification of this process is given in 
2.8.3 


2.2.7.2 Bus transfer signals 


Four signals are available on the bus to disable the 
line drivers of the permanent bus master. They are: 


1) ADSB*, address disable. 

2) DODSB*, data out disable. 

3) SDSB*, status disable. 

4) CDSB*, control output disable. 


Use of these lines is tightly specified during the 
transfer of the bus from a permanent master to a tem- 
porary master, as given in 2.8.2, and any transfer in- 
volving the control output lines should follow a 
similar protocol. 

The address, data, and status signals from the per- 
manent master may be disabled and replaced using 
these signals as long as the contents of these buses is 
valid for the current bus cycle as though no replace- 
ment had occurred. 


2.2.8 Vectored interrupt bus 


The eight lines of the vectored interrupt bus are 
used in conjunction with the generalized vectored in- 
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terrupt request, INT*, to arbitrate among eight 
levels of interrupt request priorities. They are 
typically implemented as inputs to a bus slave which 
masks and prioritizes the requests, asserts the 
generalized interrupt request to the permanent bus 
master, and responds to the interrupt acknowledge 
bus cycle with appropriate vectoring data. 

The eight lines of the vectored interrupt bus are 
У10% through VI7*, where VIO* is considered the 
highest priority interrupt. 

The vectored interrupt lines should be im- 
plemented as levels, that is, they should be held ac- 
tive until service is received. 


2.2.9 System utilities 
2.2.9.1 System power 


Power in S-100 systems is distributed to bus de- 
vices as unregulated voltages. A total of nine bus 
lines are used: 


1) +8 volts, 2 lines. 
2) +16 volts, 1 line. 
3) —16 volts, 1 line. 
4) GROUND, 5 lines. 


Ground lines are distributed across the edge 
connector such that low impedance grounds are 
available on both sides of the edge connector, and on 
both sides of the circuit cards. 

Power lines are subject to the specifications given 
in 3.2. 


2.2.9.2 System clock 


The system clock, Ф, is generated by the permanent 
master. The control timing for all bus cycles, whether 
they are cycles of the permanent master or cycles of 
temporary masters in control of the bus, must be 
derived from this clock. 

This signal is never transferred during a bus ex- 
change operation. 


2.2.93 CLOCK 


This clock is specified as a 2-MHz (0.5 percent 
tolerance) signal with norelationship to any other bus 
signal. It is to be used by counters, timers, baud-rate 
generators, etc. 


2.2.9.4 System reset functions 
System reset functions are divided into three lines: 


1) RESET", resets all bus masters. 

2) SLAVE CLR*, resets all bus slaves. 

3) POC*, power-on clear is active only on power-on, 

and asserts SLAVE CLR* and RESET*. 

The POC* signal is specified as having a minimum 
active period of 10 msec. 

RESET* апа SLAVE CLR* are specified as open 
collector lines. 
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2.2.9.5 Memory write strobe 


The memory write strobe, MWRT, must be gener- 
ated somewherein the system. Itis usually generated 
by front panel type devices, but is optionally 
generated by permanent masters or mother boards in 
systems without front panels. Care must be taken 
that it is generated at only one point in a given 
system. 

Memory write is defined as: 


MWRT = pWR * —sOUT (logic equation) 
2.2.9.6 Phantom slaves 


A line, РНАМТОМ5, is provided for overlaying 
bus slaves at a common address location. When this 
line is activated phantom bus slaves are enabled and 
normal bus slaves are disabled. 

This line is specified as an open collector line. 


2.2.9.7 Error 


The line ERROR* is a generalized error line that is 
asserted when an error of some sort (i.e., parity, write 
to protected memory) is occurring in the current bus 
cycle. 

This line is specified as an open collector line. 


2.2.9.8 Manufacturer specified lines 


Three lines which can be specified by individual 
manufacturers are provided on the bus. These lines, 
termed NDEF (not to be defined), should only be im- 
plemented as options, and shall be provided with 
jumpers so that possible conflicts may be eliminated. 

Any manufacturer MUST specify in detail any use 
of these lines. Signals on these lines are limited to 5 
volt logic levels. 


2.2.9.9 Power fail (PWRFAIL*) 

The power fail line indicates impending power fail- 
ure, and remains true until power is restored and 
РОС* is true. 
2.2.9.10 Reserved lines (RFU) 


The five remaining lines are reserved for future use 
and may not be used for any purpose. 


2.2.10 Pin list 


Pin connections to the card edge connector shall 
conform to the list given in Table 3. 


2.3 The permanent master interface 
2.3.1 General 
The permanent master interface provides the capa- 


bility to transfer device dependent messages to and 
from all bus slaves. It is responsible for the genera- 


Preliminary— Subject to Revision 


27 


РІМ М0. 


Table 3. 5-100 bus ріп list. 


SIGNAL 8 TYPE 
+8 VOLTS (B) 


+16 VOLTS (B) 
XRDY (S) 


VIO*(S) 
МИ (5) 
VI2*(S) 
VI3*(S) 
VI4*(S) 
VIS*(S) 
№16*(5) 
VI7*(S) 
NMI*(S) 
PWRFAIL* (В) 


DMA3* (М) 
A18 (M) 
A16 (M) 
A17 (M) 
SDSB* (M) 
CDSB* (M) 
GND (B) 
NDEF 

ADSB* (M) 
DODSB* (M) 
Ф (B) 
pSTVAL*(M) 
pHLDA (M) 


ВЕЦ 

ВЕЦ 

А5 (М) 

А4 (М) 

АЗ (М) 

А15 (М) 

A12 (М) 

А9 (М) 

001 (M)/DATA1 (М/5) 
DOO (M)/DATAO (M/S) 
A10 (M) 

004 (M)/DATA4 (M/S) 
005 (М)/РАТА5 (M/S) 
006 (M)/DATA6 (M/S) 
012 (S)/DATA10 (M/S) 
013 (S)/DATA11 (M/S) 
DI7 (S)/DATA15 (M/S) 
sM1 (М) 


500Т (М) 
SINP (M) 
sMEMR (M) 


ЅНІТА (М) 
CLOCK(B) 
GND(B) . 
+8 VOLTS (B) 
—16 VOLTS (B) 


GND (B) 
SLAVE CLR* (B) 


DMAO* (M) 


ACTIVE LEVEL 


H 
L 0.0 
L 0.0 
Ё 0.0 
L 0.C 
L 0.C 
L 0.C 
L 0.C 
L 0.C 
L 0.C. 
L 
L 0.C. 
H 
H 
H 
L 0.C. 
L 0.C 
Е, 0.0 
L 0.C 
H 
L 
H 
H 
H 
H 
H 
H 
H 
H 
H 
H 
H 
H 
H 
H 
H 
H 
H 
H 
H 
H 
H 
L 0.C 
L 0.C 
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DESCRIPTION 


Instantaneous minimum greater than 7 volts, instantaneous maximum less 
than 25 volts, average maximum less than 11 volts. 

instantaneous minimum greater than 14.5 volts, instantaneous maximum 
less than 35 volts, average maximum less than 21.5 volts. 

One of two ready inputs to the current bus master. The bus is ready when 
both these ready inputs are true. See pin 72. 

Vectored interrupt line 0. 

Vectored interrupt line 1. 

Vectored interrupt line 2. 

Vectored interrupt line 3. 

Vectored interrupt line 4. 

Vectored interrupt line 5. 

Vectored interrupt line 6. 

Vectored interrupt line 7. 

Non-maskable interrupt. 

Power fail bus signal. (See Section 2.10.1 regarding pseudo open- 
collector nature) 

Temporary master priority bit 3. 

Extended address bit 18. 

Extended address bit 16. 

Extended address bit 17. 

The control signal to disable the 8 status signals. 

The control signal to disable the 5 control output signals. 

Common with pin 100. 

Not to be defined. Manufacturer must specify any use in detail. 

The control signal to disable the 16 address signals. 

The control signal to disable the 8 data output signals. 

The master timing signal for the bus. 

Status valid strobe. 

A control signal used in conjunction with HOLD* to coordinate bus master 
transfer operations. 

Reserved for future use. 

Reserved for future use. 

Address bit 5. 

Address bit 4. 

Address bit 3. 

Address bit 15 (most significant for non-extended addressing.) 

Address bit 12. 

Address bit 9. 

Data out bit 1, bidirectional data bit 1. 

Data out bit 0, bidirectional data bit 0. 

Address bit 10. 

Data out bit 4, bidirectional data bit 4. 

Data out bit 5, bidirectional data bit 5. 

Data out bit 6, bidirectional data bit 6. 

Data in bit 2, bidirectional data bit 10. 

Data in bit 3, bidirectional data bit 11. 

Data in bit 7, bidirectional data bit 15. 

The status signal which indicates that the current cycle is an 
op-code fetch. 

The status signal identifying the data transfer bus cycle to an 
output device. 

The status signal identifying the data transfer bus cycle from an 
input device. 

The status signal identifying bus cycles which transfer data from memory 
to a bus master, which are not interrupt acknowledge instruction 
fetch cycle(s). 

The status signal which acknowledges that a HLT instruction has been 
executed. 

2 MHz (0.5%) 40-60% duty cycle. Not required to be synchronous with 
any other bus signal. 

Common with pin 100. 

Common with pin 1. : 

Instantaneous maximum less than — 14.5 volts, instantaneous minimum 
greater than — 35 volts, average minimum greater than — 21.5 volts. 

Common with pin 100. . 

A reset signal to reset bus slaves. Must be active with POC* and may also 
be generated by external means. 

Temporary master priority bit 0. 
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РІМ NO. SIGNAL & TYPE ACTIVE LEVEL DESCRIPTION 

56 DMA1* (M) L 0.C. Temporary master priority bit 1. 

57 DMA2* (M) L 0.C. Temporary master priority bit 2. 

58 SXTRQ* (M) L The status signal which requests 16-bit slaves to assert SIXTN*. 

59 A19 (M) H Extended address bit 19. 

60 SIXTN* (S) E 0.C. The signal generated by 16-bit slaves in response to the 16-bit request 
signal sXTRQ*. 

61 A20 (M) H Extended address bit 20. 

62 A21 (M) H Extended address bit 21. 

63 A22 (M) H Extended address bit 22. 

64 A23 (M) H Extended address bit 23. 

65 NDEF Not to be defined signal. 

66 NDEF Not to be defined signal. 

67 PHANTOM* (M/S) L 0.C. A bus signal which disables normal slave devices and enables phantom 
slaves— primarily used for bootstrapping systems without hardware 
front panels. 

68 MWRT (B) H pWR* — sOUT (logic equation). This signal must follow pWR* by not more 
than 30 ns. (See note, Section 2.7.5.3) 

69 RFU Reserved for future use. 

70 GND (B) Common with pin 100. 

71 RFU Reserved for future use. 

72 RDY (S) H 0.C See comments for pin 3. 

73 ЇМТ" (5) L 0.C The primary interrupt request bus signal. 

74 HOLD* (M) L 0.C The control signal used in conjunction with pHLDA to coordinate bus 
master transfer operations. 

75 RESET*(B) L OC: The reset signal to reset bus master devices. This signal 
must be active with POC* and may also be generated by 
external means. 

76 pSYNC (M) H The control signal identifying BS. 

77 pWR* (M) L The control signal signifying the presence of 
valid data on DO bus or data bus. 

78 pDBIN (M) H The control signal that requests data on the DI 
bus or data bus from the currently addressed slave. 

79 А0 (M) H Address bit 0 (least significant). 

80 A1 (M) H Address bit 1. 

81 A2 (M) H Address bit 2. 

82 A6 (M) H Address bit 6. 

83 А? (M) H Address bit 7. 

84 A8 (M) H Address bit 8. 

85 A13 (M) H Address bit 13. 

86 A14 (M) H Address bit 14. 

87 A11 (M) H Address bit 11. 

88 D02 (M)/DATA2 (M/S) H Data out bit 2, bidirectional data bit 2. 

89 003 (M)/DATA3 (M/S) H Data out bit 3, bidirectional data bit 3. 

90 DO7 (M)/DATA7 (M/S) H Data out bit 7, bidirectional data bit 7. 

91 014 (S)/DATA12 (M/S) H Data in bit 4 and bidirectional data bit 12. 

92 DI5 (S)/DATA13 (M/S) H Data in bit 5 and bidirectional data bit 13. 

93 016 (S)/DATA14 (M/S) H Data in bit 6 and bidirectional data bit 14. 

94 011 (S)/DATA9 (M/S) H Data in bit 1 and bidirectional data bit 9. 

95 DIO (S)/DATA8 (M/S) H Data in bit 0 (least significant for 8-bit data) and 
bidirectional data bit 8. 

96 sINTA (M) H The status signal identifying the bus input cycle(s) that may 
follow an accepted interrupt request presented on INT*. 

97 sWO* (М) L The status signal identifying a bus cycle which transfers 
data from a bus master to a slave. . 

98 ERROR* (S) L 0.C. The bus status signal signifying an error condition during 
present bus cycle. 

99 POC* (B) L The power-on clear signal for all bus devices; when this 
signal goes low, it must stay low for at least 10 msecs. 

100 GND (B) System ground. 


trol of the bus is always returned to the permanent 
master. 


tion and timing of all bus cycles while it has control of 
the bus, and is capable of generating all possible bus 
cycles. 
2.3.2 Permanent master state diagram 
The permanent master normally has control of the 
bus. It may relinquish bus control to a temporary bus 
master via a hold operation for an arbitrary number 
of cycles. Upon completion of the hold operation con- 


The permanent master interface shall be im- 
plemented so as to conform to the state diagram 
given in Figure 1. 
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2.3.3 Permanent master state descriptions 
2.3.3.1 Bus state 1 


The initial bus state, BS), is the state in which the 
status and address buses are in transition to their 
values for the new bus cycle. pSYNC goes true in the 
middle of the BS, state, indicating the beginning of a 
new bus cycle. 


2.3.3.2 Bus state 2 


Bus state 2, BS», is the state during which the ad- 
dress and status lines become stable. When they are 
guaranteed stable the pSTV AL*, status valid strobe, 
is activated. 

The ready lines and the sixteen acknowledge line 
are sampled during the BS; state. 


2.3.3.3 Wait state 


The wait state, BS,, is entered if the ready line 
sampled in BS; indicates that the addressed bus 
slave is not ready for data transfer. The ready line is 
sampled once every clock cycle until a ready condi- 
tion is indicated. When the ready condition is in- 
dicated the BS» state is completed and the BS; state 
entered. 

The BS, state is thus used to synchronize bus 
cycles generated by bus masters with the response 
speed of assorted bus slaves. 


2.3.3.4 Bus state 3 


Bus state 3, BSs, is the bus state during which the 
data transfer actually takes place between the master 
and the addressed slave. 


= HOLD" 7 pHLDA - F 

minimum specitied time delay between hold and hald acknowledge. 

tion execution complete + INT enable + INT request / interrupt accept 
cution not бот INT disabled + no interrupt request 


Figure 1. Permanent master state diagram. 
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2.3.3.5 Idle bus states 


After completion of the BS; state, the master may 
enter one or more idle bus states. 

While in an idle bus state the generalized data 
strobes, pWR* and pDBIN, must not be active, and 
pSTVAL* must not be asserted in conjunction with 
pSYNC active. 


2.3.3.6 Hold accept 


Permanent masters must be configured to condi- 
tionally accept hold operations from temporary 
masters. This function may be gated off under hard- 
ware or software control, to allow indivisible test and 
set operations. If hold is enabled and active, the per- 
manent master will enter the hold state HS following 
a BS3 state, and pHLDA will be asserted. 

The permanent master remains in the hold state un- . 
til the hold request HOLD* becomes false. 

Hold operations always take priority over inter- 
rupt operations. 


2.3.3.7 Interrupt accept 


If hold request is not active, if execution of the cur- 
rent instruction is complete, and if interrupts are 
enabled and an interrupt is being requested, then the 
permanent master accepts the interrupt request at 
the end of the Вб; state. In the case of a vectored in- 
terrupt, the next bus cycle may be an interrupt : 
acknowledge bus cycle. In the case of a non-maskable 
interrupt, the response is usually a transfer to a 
predetermined location. 


2.3.4 Required signals for permanent masters 
2.3.4.1 Output signals 


The following signals are output signals from per- 
manent masters to bus slaves: 


1) А0-А231. 

2) Allstatus signals. 

3) All control output signals. 

4) Data output signals (8 or 16 depending on pro- 
cessor type). 

5) Ф, the system clock. 


2.3.4.2 Input signals 


The following signals are required input signals to 
permanent masters: 


1) The control input signals, except NMI* and 
SIXTN*. 

2) Data input signals (8 or 16 depending on pro- 
cessor type). 

3) The four disable signals ADSB*, DODSB*, 
SDSB*, CDSB*. 

4) RESET*. 


T A16 through A23 are optional on permanent masters. 
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2.3.5 Dummy mastering 


Incases where a number of processors co-exist in a 
single system as temporary masters, it may prove in- 
efficient from a systems point of view to implement a 
permanent master. 

In such a case it is permissible that the permanent 
master be implemented as a dummy, that is, as a 
device that conducts no bus cycles, but only supplies 
an arbitration interval so that Ше ОМА control bus 
may settle. 

Тһе dummy master takes control of the bus be- 
tween temporary masters, asserting the control out- 
put bus in the null state, and passes the bus to the 
next requester after an arbitration interval of one 
clock cycle. 

Required output signals for dummy masters are 
the control output signals, and the system clock Ф. 
Input signals are HOLD* and CDSB*. 


2.4 The temporary master interface 


2.4.1 General 


quester is granted the bus on the rising edge of hold 
acknowledge. 


2.4.3.2 Bus transfer states (XS I and XS II) 


Since the bus has positive polarity control signals, 
extreme care must be taken in bus transfer opera- 
tions to avoid erroneous pulses on the control lines. 

In general terms, this is accomplished by specify- 
ing that both the permanent master and the tem- 
porary master drive the control lines in specified logic 
states during the bus transfer. 

Detailed specification of this operation is given in 
2.8.2. 


Proposed S-100 bus layout—Quick reference 


pint +8 Volts (B) pin51 +8 Volts (В) 

The temporary master interface provides the 4:25 Yu e H HE 55 е Vans do) 
capability to transfer device dependent messages to pin4 Мо" (S) L pin 54 SLAVE СІН" (B) L 
and from a selected set of bus slaves. The temporary pinS УІ“ (S) ? рїп i үүн, М) E 
master thus differs from the permanent master in ne ү D Ч йн а сийн Wi Ё 
that it need not generate all possible bus cycles. pin8 м4 (S) L pin 58 зхтва" (M) L 

The temporary master requests control of the bus ping = VI5* (S) L ріп 59 A19 — ч 
from the permanent master. If the bus is granted, the за T. am 2 t ын S UA Өө) Ч 
temporary master is responsible for the generation ріп 12 ММ!" (S) L ріп 62 А21 (М) H 
and timing of all bus cycles until it returns control to pin 13 PWRFAIL* (B) Е pin 63 А22 (М) H 
the permanent master pin 14... DMAS* (M) т pin P ша i 

: ` ER. іп 15 А18 (M pin 

| Since up to 16 temporary masters may co-exist ina bin 16 A16 Юу H ріп 66 NDEF 
single system, a protocol has been developed to ar- ріп 17 А17 (М) H pin 67 PHANTOM“ (M/S) L 
bitrate among simultaneous bus requests. Detailed ИП 2 der. uj Ё ри, МУТ (8) Ч 

specification of this protocol is given in 2.8.3. pin20 GND pin 70 GND 

ріп21 ВЕЦ ріп 71 NDEF 
j pin 22 ADSB* (M) L pin 72 RDY (S) H 
2.4.2 Temporary master state diagram pin 23 DODSB* (M) L ріп 73 INT* (6) L 
. . ріп 24 Ф (В) H pin 74 НОО" (M) L 

The temporary master interface shall be im- ріп 25 pSTVAL* (M) L ріп 75 RESET* (B) L 

plemented so as to conform to the state diagram pin 26 pHLDA (M) 4 ріп 76 ^p YNO (M) > 
Е in Fi 2 pin 27 RFU pin 77 pWR* (M) L 
given in Figure 2. pin 28 ВЕЦ pin 78 pDBIN (M) H 
pin 29 АБ (M) H ріп 79 А0 (М) H 

2.4.3 Temporary master state descripti pin 30 А4 (M) H ріп 80 А1 (М) H 
ы дананы аны ріп 31 АЗ (М) H ріп 81 А2 (М) H 

T ріп 32 А15 (М) H pin 82 A6 (М) H 

2.4.3.1 Arbitration (ARB) ріп 33 A12 (M) H pin 83 A7 (М) H 
pin 34 А9 (М) H ріп 84 А8 (М) H 

я : pin 35 DO1(M)IDATA1 (M/S) Н ріп 85 А13(М) H 

If morethan onetemporary master is present in the ріп 36 DOO(MYDATAO(MIS) H pin 86 A14 (M) H 
system, bus requesters must arbitrate for the bus as ріп 37 А10 (М) H pin 87 А11 (М) H 
given in 2.8.3. ріп 38 004 (МУОАТА4 (M/S) Н ріп 88 ОО2(МУРАТА2(М5) Н 

During the arbitration sequence, bus requesters гн ээр Ms) Н Ёо цэ ООМА. dene Н 

а= ыту oe : pin pin 
try to assert their priorities on the arbitration bus, pin41 DI2(S/DATA10(M/S) H ріп 91 014 (SJDATA12 (M/S) H 
and the contents of the arbitration bus are compared pin 42 013 (SJDATA11(M/S) Н ріп 92 DI5(S/DATA18 (M/S) Н 
with each requester's priority ріп 43 017 (S)IDATA15 (M/S) а ріп 93 016 (5/рАТА14 (M/S) Н 
Ж”. . . ріп 44 sM1 (М) ріп 94 011 (5УРАТА9 (M/S) Н 

If the contents of the arbitration bus is of higher ріп 45 sOUT (М) H ріп 95 DIO (SJDATAB а H 
priority than the locally attempted priority asser- | pin46 sINP(M) H pin 96 sINTA (М) | H 
tion, then a higher priority requester is present in the e i ER oe, + pu 3 Ва k 
system, and the low priority requester removes its pin 49 CLOCK (B) ріп 99 POC* (B) L 
low order bits from the arbitration bus. Thus, after ріп 50 GND 


pin 100 GND xpo 
some settling time, the priority of the highest priority ата 
requester is present on the arbitration bus. This ге- 
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2.4.3.3 Bus cycle 


The definition of bus cycle states is the same as 
that for the permanent master interface, given in 
2.3.3.1 through 2.3.3.5. 

An arbitrary number of bus cycles may be per- 
formed by the temporary master before returning 
control to the permanent master. 


2.4.4 Required signals for temporary masters 
2.4.4.1 Output signals 


The following are required output signals for a tem- 
porary master interface: 


1) Address lines A0-A23T. 

2) All status signals. 

3) All control output signals tt. 

4) Data output lines. 

5) DMA arbitration lines DMA0*-DMA3*. 
6) Hold request, HOLD*. 


2.4.4.2 Input signals 


The following are required input signals for a tem- 
porary master interface: 


t Note: Temporary masters must generate A16-A23; they need only 
generate falses or lows on these 8 lines, however. 

tt Note: Temporary masters should provide a jumper оп (һе 
pSTVAL+ line, as 8080 CPUs of old design do not transfer this line 
with the control output lines. In this case all bus masters use the 
same pSTV AL* signal. 


BUS REQUEST 


[1] t- DONE) * -IDLE 
121 ( — DONE) * IDLE 


Figure 2. Temporary master state diagram. 
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1) The ready lines, RDY and XRDY. 
2) Hold acknowledge, pHLDA. 

3) Data input lines. 

4) The system clock, Ф. 


2.5 The slave interface 


A slave device responds to a bus cycleinitiated by a 
bus master. Memory and input/output devices are ex- 
amples of bus slaves. 

A slave device may request service by a bus master 
by generating an interrupt request. 


2.5.1 Slave interface state diagram 


The slave interface shall conform, in general, to the 
state diagram given in Figure 3. Slave interfaces need 
not have both read and write capability. 


2.5.2 Slave state definitions 
2.5.2.1 Slave idle state 


The slave idle state, 5;, is a passive state with 
respect to the bus. 

The slave monitors the stream of bus cycles to 
determine if it is selected for the current bus cycle. 

The slave may be performing internal operations 
while in the idle state. 

The assertion of SLAVE CLR* forces all slaves in- 
to the idle state. 


2.5.2.2 Slave setup 


A slave moves from the slave idle state to the setup 
state, 5,, when it has been addressed by the current 
bus cycle. This is an operation internal to the slave 
which sets up a data transfer with a bus master. If a 


-Sm 
INTERRUPT 
INTERRUPT mem 
SERVICE 
+ SLAVE CLR* | 
: (-0SELA 
+ SLAVE Y DSEL/RDY 


CLR* 


(— DSEL) + SLAVE CLR* 


WHERE: — DSEL = DEVICE SELECT (iNTERNAL TO SLAVE} 
S, = SLAVE ILE 

-5, = SLAVE SETUP 

S, = SLAVE READ 

‘Sy = SLAVE WRITE 

‘Sin = SLAVE INTERRUPT 


Figure 3. Slave interface state diagram. 
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slave can tolerate spurious transitions from the idle 
state to the setup state, then the device select signal 
may be decoded statically from the address and status 
buses. If a device cannot tolerate spurious transitions, 
the device select line should be decoded in conjunction 
with the status valid strobe, pSTVAL*. 

If synchronization is required by the slave before 
the data transfer may take place, the ready line is 
asserted false during this state until the device is 
ready for data transfer. 


2.5.2.8 Slave read 


Data from the addressed slave is gated onto the 
data bus during the slave read state, S,. The gener- 
alized read strobe governs the transition to this state. 

When device select becomes false the slave returns 
to the idle state. 


2.5.2.4 Slave write 


Data from the current bus master is written into 
the slave during the active period of the generalized 
write strobe, pWR*. 

When device select becomes false the slave returns 
to the idle state. 


2.5.2.5 Interrupt request state 

If a slaverequires service by a bus master, an inter- 
rupt request may be generated by the slave. The in- 
terrupt should be held active until the slave is ser- 
viced, or until SLAVE CLR* is asserted. 
2.5.3 Required signals for slave interfaces 

Slave interfaces need only receive and generate 


that subset of bus signals necessary for communica- 
tion with masters. 


2.6 8/16-bit data transfer protocol 
2.6.1 General 
Implementation of the 8/16-bit data transfer pro- 


tocol allows both 8-bit and 16-bit parallel data 
transfers over the bus, and hence allows both 8-bit 


masters and 16-bit masters and slaves to co-exist ina 


single system. For 16-bit transfers the two unidirec- 
tional 8-bit data buses are ganged to form a single 
16-bit bidirectional data bus. 

Two lines are assigned to control the ganging of the 
data bus: 


1) sXTRQ*, status output from the master, which 
indicates a request for a 16-bit data transfer. 

2) SIXTN*, an acknowledge input to the master, 
which indicates that a 16-01 data transfer is 
possible. 


Use of the sixteen acknowledge line SIXTN* per- 
mits the use of current design 8-bit memory boards 
without modification. When SIXTN* is false, a 16-bit 
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transfer may be accomplished by two sequential 
single-byte transfers. 


2.6.2 8-bit data paths 


The current bus master requests an 8-bit transfer 
by not asserting sX TRQ*. 

Byte data output from the master to the addressed 
slave is asserted on the data output bus, DOO 
through ПОТ. 

Byte data input from the addressed slave to the 
current bus master is asserted on the data input bus, 
DIO through DIT. 


2.6.3 16-bit data paths 


The current bus master requests a 16-bit transfer 
by asserting sXTRQ*. 

If the addressed slave is capable of a 16-bit parallel 
data transfer, it asserts SIX TN*, as shown in the tim- 
ing diagram (see page 52). 

Sixteen-bit data transfer is then conducted via the 
ganged data buses, where DOO = DATAO, and DI7 
= DATAI5. 


2.6.4 Memory organization 


Memory devices capable of both 8-bit and 16-bit 
parallel data transfers are organized, as shown in 
Figure 4, as two banks of 8-bit memory, a high-byte 
bank and a low-byte bank. These data banks may be 
activated either together or separately, depending on 
the condition of the sixteen request status line, 
sXTRQ*. 


2.6.4.1 Byte references 


When sX TRQ* is not asserted, memory references 
are single-byte transfers. 


TRI-STATE DRIVERS 
WITH ENABLE f 
Di 


HIGH BYTE 


WRITE 
LOW BYTE 
WRITE 


SEL selects A for word references. B for byte references 


Output enables A= 162 + (Bg * 40) 
Ве 86330 
C= 1 5 
На = 16, + (Bwr e -А0) 
Lwe= 16, + (Bwr • А0) 
Where: 18rq= Device select • SXTRQ* + pDBIN 


Brgø= Device select *( ~ SXTRQ*) + pDBIN 
i6wre  — Device select + sXTRO* * pWR* 
Әмет 


Device select «(-5ХТВ0%). pWR* 


Figure 4. 8/16-bit memory organization. 
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Тһе proper location іп memory is selected by the 
address output on address lines А1 through A15 
(A23 for extended addressing systems), while the AO 
line selects the high byte or the low byte. А0 equals 0 
selects the high byte of the 16-bit word, while АО 
equals 1 selects the low byte of the word. 

See Figure 5 for address usage. 

In the 8-bit mode, data output from the master, on 
the DO bus, is connected to the data input lines of 
both memory banks; the low-byte data input lines are 
connected directly to the DO bus, and the high-byte 
data input lines are connected to the DO bus via a 
two-to-one multiplexer controlled by sX TRQ*. 

Data output from the memory banks is routed to 
Tri-Statet bus drivers A and B in Figure 4. One of 
these drivers is enabled when the read strobe is ac- 
tivated, depending on the condition of А0. Тһе se- 
lected byte is thus available to the master on the DI 
bus. 


2.6.4.2 Word references 


When sXTRQ* is asserted by the master, and 
SIXTN* is asserted by the slave, memory references 
are double-byte transfers. 

Address lines Al through A15 (A23 in extended ad- 
dress systems) select the proper word from memory. 
The condition of the АО bit does not enter into the 
decoding or addressing for word references. 

See Figure 5 for address usage. 

In the 16-bit mode, data output from the bus 
master is asserted on the 16 signallines of the DO bus 
and the DI bus. The multiplexer on the data input 
lines now routes the high-byte data, on the DI bus, to 
the data input lines of the high-byte bank. Low-byte 
data, on the DO bus, is connected to the data input 
lines of the low-byte bank. 

Data output from the memory banks is routed 
through buffers A and C to their respective data 


tTri-State is a trademark of National Semiconductor. 


16-BIT DATA TRANSFER 
A23 A1 A0 
әне |) | 


DON'T CARE 


DO LOW BYTE DO 


8-BIT DATA TRANSFER 
АТ A0 


А23: 


HIGH BYTE К 


$a 


| HIGH BYTE LOW BYTE | 
A0-F А0-Т 


08 07. 


Figure 5. 8/16-bit address and data usage. 
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paths. Both A and C will be enabled by the read 
strobe. 


2.6.5 Sixteen acknowledge (SIX TN"*) 


Implementation of the sixteen acknowledge line 
allows the use of 8-bit memory boards in a 16-bit 
system without modification, but with a reduction in 
maximum system bandwidth. 

Ifa 16-bit master requests а 16-bit transfer, but the 
addressed slave is not capable of such a transfer, the 
sixteen acknowledge lines will not be asserted. 

Тһе master will respond іп one of two ways, by gen- 
erating an error trap or by conducting the transfer in 
byte-serial fashion. 


2.6.5.1 Byte-serial response 


If the sixteen acknowledge line is not activated 
after a specified period, circuitry may be included on 
bus masters to conduct the requested 16-bit transfer 
as two consecutive byte operations, thus assembling 
the requested 16-bit word while holding the master in 
a wait state. 

For this process to occur, the sixteen acknowledge 
line must meet the timing specifications for the ready 
line inputs. 


2.6.5.2 Error response 


If circuitry does not exist on the master to conduct 
the requested 16-bit transfer ав two consecutive byte 
operations, an error condition shall result immediate- 
ly, with ERROR* asserted. 


2.7 Fundamental bus cycle timing 
2.7.1 General 


This section deals with the fundamental timing 
concepts involved in the standard bus cycle. Detailed 
specification of the timing parameters discussed in 
this section is given in 3.8 and 3.9. 

The standard bus cycleis a pseudo-synchronous cy- 
cle, that is, the timing of the control signals bears a 
specified relationship to the master system clock Ф. 

АП data transfers, including read or write cycles, 8- 
or 16-bit transfers, memory or input/output device 
transfers, and interrupt acknowledge are conducted 
on the bus as a standard bus cycle. 

Figure 6 shows the fundamental timing for a stan- 
dard bus cycle, with a single wait state inserted by 
the addressed slave. 


2.7.2 Address and status buses 

The beginning of a new bus cycleis indicated by the 
rising edge of the pSYNC signal, which closely fol- 
lows the rising edge of the system clock, Ф. 


The address and status buses are changing to their 
values for the new cycle during the beginning of the 


t See possible exception, section 2.7.5.3. 
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pSYNC interval. Shortly after they сап be guaran- 
teed stable on the bus, the status valid strobe, 
pSTVAL*, is asserted. pSTVAL*, decoded in con- 
junction with pSY NC, indicates to all bus slaves that 
stable address and status may be sampled from the 
bus. 

The position of the status valid strobe within the 
pSYNC interval is independent of the system clock, 
Ф. This affords the designer of bus masters con- 
siderable flexibility in interfacing different pro- 
cessors to the bus. The status valid strobe should be 
positioned within the pSYNC interval such that the 
delay between guaranteed status on the bus and the 
activation of the status valid strobe is as close to the 
minimum specification as possible, thus maximizing 
memory and device access time. T 

In order to prevent false cycle starts in bus slaves, 
only one negative edge of the status valid strobe may 
occur while pSYNC is asserted. 

Address and status information is thus stable on 
the bus from the negative transition of the status 
valid strobe during pSYNC, and is held stable until a 
specified period after the trailing edge of the data 
strobe (pDBIN in the read case, and pWR* in the 
write case) This hold time ensures that false 
decoding of the address and status information will 
not occur at the end of the bus cycle. 


2.7.8 Ready and sixteen acknowledge lines 


Тһе sixteen acknowledge line, since it may be used 
to place the bus master in a wait state while a re- 
quested 16-bit transfer is conducted in byte-serial 
fashion, is subject to the same timing constraints as 
the ready lines. 

Тһе ready lines are first sampled by the bus master 
on the rising edge of the system clock during the BS 2 
state, and if active, the master enters a wait state, 
sampling the ready line once every clock cycle on the 
rising edge of the system clock until the slaveis ready 
for data transfer. 

A minimum setup time before therising edge of the 
system clock, and a minimum hold time after samp- 
ling must be met for the proper operation of the ready 
lines. 

The time between the active edge of the status 
valid strobe and the sampling of the ready line may be 
very short. Hence, it is recommended practice not to 
make assertion of the ready line dependent on 
pSTVAL*. 

Data output, address, and status are held stable 
during wait states. 


2.7.4 Read cycles 
2.7.4.1 General 

There are four types of read cycles: op-code fetch 
(M1), memory read, input, and interrupt acknow- 


ledge. These cycles are all similar with respect to tim- 


tNote: The $1 signal output from current 8080 processor boards 
meets all the specifications as a status valid strobe. Hence, these 
beards meet the bus cycle specification without modification. 
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ing, but make different use of the status bits and the 
address bus. See Tables 1 and 2. 


2.7.4.2 The read strobe 


Тһе generalized read strobe pDBIN is used to gate 
data from an addressed slave onto the data bus dur- 
ing a read operation. The read strobe is asserted true 
by the bus master after a minimum specified time 
from the assertion of the status valid strobe. 

It is held true during any inserted wait states, and 
returns to the false state, returning the data bus to 
the high impedance state, shortly before the address 
and status buses are allowed to change. 


2.7.5 Write cycles 
2.7.5.1 General 


There are two possible types of write cycles on the 
bus, a memory write cycle and an output cycle. 

These two cycles are similar with respect to timing, 
but make different use of the status bits and address 
bus. A special write strobe, MWRT, is generated for 
memory cycles. 


2.7.5.2 The write strobe 


The generalized write strobe, pWR*, is used to 
write data from the data bus into the addressed bus 
slave. The write strobe may beasserted by the master 
after the completion of the pSYNC interval. 

Data out on the data bus must be guaranteed valid 
for a specified period both before and after the activa- 
tion of the write strobe. Hence, either the leading or 
the trailing edge of the write strobe may be used to 
strobe data into the addressed slave. 

Address and status information must be held valid 
for a specified period of time from the trailing edge of 
the write strobe. 


| BS, | BS; | BS, | 853 | BS, | 
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Figure 6. Bus cycle fundamental timing relationships. 


Preliminary—Subject to Revision 


35 


2.7.5.8 Memory write strobe 


Whilethe generalized write strobe is activated for all 
write cycles, the memory write strobe is activated for 
memory write cycles only. The memory write strobe is 
usually generated by front-panel devices, if they exist 
in the system, as a function of bus memory write or a 
front-panel deposit. If front-panel devices do not exist 
the memory write strobe must be generated 
somewhere in the system, but at only one point. This 
circuit should be designed such that it generates the 
memory write strobe for all bus masters. Jumpers 
shall be provided to allow extra circuits to be disabled. 

Тһе memory write strobe, MWRT, is defined as: 


MWRT = pWR • —sOUT, (logic equation) 


that is, memory write is true when pWR is true and 
SOUT is false. 

The memory write strobe must follow the pWR* 
strobe by not more than a specified period. t 


2.8 Special bus operations 
2.8.1 General 


This section describes two special bus operations 
related to DMA operations, that is, the transfer of 


tNote: Historically the MWRT strobe has been generated by front- 
panel devices to accomplish the deposit function. In such a case, the 
МУУВТ strobe is asserted while the front-panel holds the CPU in a 
wait state during a memory read cycle. Note that the status will in- 
dicate a read cycle and the pDBIN strobe will be active. 

While this is acceptable procedure for 8-bit systems, and 8-bit 
memories should respond to MWRT as well as pWR*, it is not per- 
missible in 16-bit systems as a conflict will exist on the bidirectional 
data bus. A front-panel could be implemented either as a temporary 
master, or integrated into the CPU. 


Figure 7. Bus transfer state diagram. 


Preliminary —Subject to Revision 


36 


bus control from the permanent bus master to a tem- 
porary bus master for an arbitrary number of bus 
cycles, and the return of control to the permanent bus 
master. 

These two operations are: 


1) The bus transfer protocol. 
2) The arbitration protocol among simultaneous 
bus requesters. 


2.8.2 Bus transfer protocol 
2.8.2.1 General 


When a temporary bus master has been granted 
the bus by the permanent bus master, control must 
be transferred to the temporary master in such a way 
that spurious signals are not generated on the control 
output lines, causing false bus cycles. Since some of 
the control output signals are of positive polarity, ex- 
treme care must be taken in this operation. In 
general, the specified bus transfer protocol ac- 
complishes this by having the permanent master and 
the temporary master drive the control output lines 
simultaneously at specified levels during the bus 
transfer. 


2.8.2.2 Bus transfer state diagram 


The bus transfer operation shall be implemented so 
as to conform to the bus transfer state diagram given 
in Figure 7. 


2.8.2.3 Bus transfer state definitions 
2.8.2.3.1 Idle 


The idle state signifies that the temporary master 
is either involved in internal operations, and does not 
require the bus, or that it is waiting for the bus to 
become free so that it may assert its bus request. 


2.8.2.3.2 Arbitration 


If a temporary master desires the bus, and HOLD 
is false and pHLDA is false, the temporary master 
enters the arbitration sequence, where it contests 
with other bus requesters for control of the bus. 

Detailed specification of this process is given in 
2.8.3. 


2.8.2.3.3 Bus grant 


Priority assertions on the arbitration bus settle in 
the interval between the assertion of a hold request 
and ahold acknowledge. At the rising edge of the hold 
acknowledge signal the bus is granted to the highest 
priority requester, enabling the bus transfer opera- 
tion for that requester. 

If the bus is not granted to a requester, that re- 
quester returns to the idle state. 

The bus grant state is termed MINE. 
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2.8.2.3.4 Transfer state one, XS I 

Тһе bus transfer sequence begins with transfer 
state one, XS I. The bus transfer control circuit 
asserts the following signals together: 


1) ADSB* 
2) SDSB* 
3) DODSB* 


disabling the address, status, and data output 
drivers of the permanent bus master and enabling the 
control output drivers of the temporary master. Both 
the permanent master and the temporary master are 
now driving the control output lines. These lines are 
required to have the following levels during this time. 


Signal Logic state Electrical level 
1) pSYNC F L 
2) pSTVAL* F Ht 
3) pDBIN F L 
4) pWR* F H 
5) pHLDA T H 


The transfer state is terminated by the assertion 
(by the bus transfer control circuit) of the CDSB* 
line, disabling the control drivers of the permanent 
master and enabling the address, status, and data out 
drivers of the temporary master. The temporary mas- 
ter now has complete control of the bus and begins its 
first bus cycle. 


2.8.2.3.5 Bus cycles 


Any number of standard bus cycles are then con- 
ducted by the temporary bus master. Bus control is 
never transferred between cycles. When the tem- 
porary master is done, the process proceeds to XS II, 
transfer state two. 


2.8.2.3.6 Transfer state two 


Transfer state two, XS II, isthe mirror image ofthe 
sequence in XS I. The state begins with the release of 
the CDSB* signal, enabling the control output drivers 
of the permanent master and disabling the address, 
status, and data output drivers of the temporary 
master. 

Both the temporary master and the permanent 
master drive the control output lines for the re- 
mainder of XS II at the levels prescribed for XS I. 

The state is ended by the release of other disable 
signals and HOLD*, enabling the address, status, 
and data out drivers on the permanent master, and 
disabling the control output drivers of the temporary 
master. The permanent master now has complete 
control of the bus and the temporáry master returns 
to the idle state. 


2.8.2.4 Bus transfer timing relationships 
2.8.2.4.1 General 


The fundamental timing relationships for a bus 


+See note in section 2.4.4.1. 
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transfer and a single DMA bus cycle are given in 
Figure 8. 

Relationship to the bus transfer states is shown in 
boxes at the bottom of the figure. 

Detailed specification of these times is given in 3.10 


and Table 5. 


28242 Tset 


A minimum time between the rising edge of the 
hold acknowledge signal and the assertion of the 
disable signals in XS I allows time for completion of 
the preceding bus cycle. 


282.43 Toy 

The time that both the temporary master and the 
permanent master must drive the control output 
signals has a specified minimum to assure a smooth 
bus transfer. 

Assertion of the XFER II signal, or CDSB*, is 
specified relative to the rising edge of the system 


сіосК,. Ф, so that the assertion of this signal may be 
used by the temporary master as a cycle start signal. 


28244 Ty, 

The “4опе” signal is a signal internal to the tem- 
porary master. This signal should not be asserted un- 
til the hold time for data output, status, and address 
signals in the standard bus cycle has been met. 
28.245 Trel 

Completion of the reverse bus transfer XFER II 


shall precede the release of the pHLDA signal by a 
minimum specified time. 


Ф 


pHLDA 
XFER I 
XFER II 
pSYNC 


pDBIN 


pWR* 


DONE 


HOLD* / 


WHERE: 
XFER | = ADSB*, SDSB*, DODSB* 
XFER I| 2 CDSB* 


Figure 8. Bus transfer and single bus cycle. 
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Note: This state diagram 15 conceptually correct. but this process is Ақ а 
parallel rather than а sequentia! one. Figure 9B shows suitable logic to imple- 
ment such a parallel process. 


Figure 9a. Bus arbitration diagram. 
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2.8.3 Bus arbitration protocol 


Ina system which allows more than one master to 
use the system bus, for example a CPU permanent 
master and several temporary masters such as DMA 
controllers or multiple CPUs, some means must be 
provided to determine which device will be allowed to 
control the bus at any given time. 

The bus arbitration system uses four bus lines for 
arbitrating among 16 temporary masters. These lines 
are driven by open collector drivers, and are pulled 
high by pullup resistors. Each temporary master has 
a unique priority number which it asserts on the ar- 
bitration bus at an appropriate time. A higher binary 
number indicates a higher priority. 

The temporary masters compare the priority ap- 
pearing on the active-low open-collector bus with the 
priority they are asserting, starting with the most 
significant bit. If disagreement is detected by any 
temporary master at any given bit position, then 
another temporary master must be asserting that 
priority bit and thus must have a higher priority. In 
that case all less significant bits are removed by the 
detecting temporary master. АП more significant 
bits agree, and thus need not be removed, and the bit 
which disagreed must have been a 0 and thus was not 
asserted. Leaving the agreeing bits asserted reduces 
system noise caused by the redistribution of driving 
currents in the bus, and speeds settling of the correct 
priority on the arbitration bus. This process is a con- 
tinuous asynchronous parallel process, not a sequen- 
tial bit-by-bit process as it may seem from the above 
description. Incorrect comparisons will occur and be 
removed as the bus lines settle for as long as four bus 
delays (not related to the choice of four bus lines) plus 
logic delays. 

The four lines which comprise the arbitration bus 
are DMAO* through DMA3*, where ОМ АЗ* is the 
most significant bit. These lines, in conjunction with 
HOLD* and pHLDA, control the bus arbitration pro- 
cess. 


2.8.3.1 Bus arbitration implementation 


An implementation of the bus arbitration protocol 
is shown in Figures 9a and 9b. 

Any implementation shall obey the rules sum- 
marized in section 2.8.4. 


2.8.3.2 Bus arbitration state definitions 
28.3.2231 IWANT 


The IWANT state is an internal state for a tem- 
porary master which has determined that a bus ac- 
cess is necessary and thus wishes to arbitrate for bus 
control. 

Temporary masters may not assert their priorities 
nor remove them at arbitrary times, or the arbitra- 
tion bus may be in transition when the result is need- 
ed. A temporary master may assert its priority and 
the HOLD* bus request only if (1) pHLDA is not 
asserted (the permanent master has the bus), and (2) 
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HOLD* is not already asserted. This guarantees ап 
ample time to settle the arbitration bus before the 
granting of the bus on the rising edge of pHLDA. 

This scheme usually results in the first requester 
winning the bus. Only if simultaneous bus requests 
occur will the arbitration have any effect. This, 
however, is not improbable, since multiple unsuc- 
cessful requesters will become synchronized by 
waiting for the falling edge of pHLDA. 


2.8.3.2.2 Priority compare states 


The priority comparison states, C3 through СО, are 
the states where each requester compares the priori- 
ty it is attempting to assert on the arbitration bus 
with the priority actually on the arbitration bus. 
Though C3 through СО are shown and described as se- 
quential, they are actually parallel processes. While 
disagreement occurs at any bit position, less signifi- 
cant bits are removed from the arbitration bus. If no 
disagreement persists after the settling time, the re- 
quester has the highest priority and will be granted 
the bus on the rising edge of pHLDA, proceeding to 
the state "MINE", where the bus transfer begins. АП 
requesters continue to assert their priorities on the 
arbitration bus until the falling edge of pHLDA. 
Thus the priority number of the current bus master is 
available on the DMA bus while pHLDA is true. If 
the permanent master has the bus, pHLDA will be 
false. 

A temporary master that wins the bus continues to 
assert its priority and HOLD* untilits bus cycles are 
complete. A temporary master that loses the bus con- 
tinues to assert its priority bits not turned off by the 
arbitration process, but must remove its assertion of 
the HOLD* line, sothat the winner may indicate that 
itis finished by releasing HOLD*. A losing requester 
in this state is said to be in the “WAIT” state. 


2.8.3.3 Bus arbitration timing relationships 


Figure 10 shows two possible cases of the bus ar- 
bitration procedure. The first of these is a case where 
the requester has no competition; it requests the bus 
and the bus is granted. The second case shows the re- 
quester waiting for the bus to be free, arbitrating for 
the bus and losing, and arbitrating for the bus and 
winning. 


2.8.3.3.1 No competition 


When the temporary master determines that it re- 
quires the bus, it raises the internal signal IWANT. 
In this case, the rising edge of IWANT finds the 
pHLDA signal unasserted, meaning the permanent 
master has the bus, and the HOLD* signal unas- 
serted, meaning that no other devices are requesting 
the bus. The temporary master may then assert the 
HOLD* signal and assert its priority on the arbitra- 
tion bus. The ISME signal is theresult of the arbitra- 
tion process, and is asserted if none of the bit-wise 
comparisons on the arbitration bus fail. This arbitra- 
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tion result is clocked by therising edgeofthepHLDA 
signal, creating the bus grant signal MINE. 

When the temporary master is finished with the 
bus, the IWANT signal is released, releasing the 
HOLD* signal and resetting the bus grant signal, 
MINE. The permanent master releases the pHLDA 
signal, and all assertions are removed from the ar- 
bitration bus. 


2.8.3.3.2 Wait-lose-win 


In this example the requester raises its IWANT 
signal, but finds the bus already busy and must wait 
to assert its bus request and priority until the falling 
edge of pHLDA. 

Тһе requester arbitrates for the bus during try 1, 
but another requester has a higher priority and the ar- 
bitration result ISME is low at the rising edge of 
pHLDA, indicating a loss in the arbitration process. 
The losing requester removes its assertion of the 
HOLD* signal, but continues to assert the non-con- 
flicting high-order bits of its losing priority until the 
faling edge of pHLDA. At the falling edge of 
pHLDA, the process repeats, but this time results in 
a win for the requester. 


2.8.4 Summary of arbitration protocol 


Figures 9A and 9B represent an example, not a re- 
quired implementation. Any implementation which 
obeys the rules may be used. The rules which must be 
obeyed by a temporary master are: 


1) HOLD* may be asserted only when it is not 
already asserted and pHLDA is low. 

2) HOLD* must be removed when pHLDA rises if 
another controller has asserted higher priority. 

3) HOLD* must be removed when the controller по 
longer needs the bus. 

4) Priority must be asserted whenever HOLD* is 
asserted, and must remain asserted until the 
next falling edge of pHLDA. 


NO COMPETITION 


WAIT TRY 1 TRY2 


Figure 10. Bus arbitration timing diagrams. 
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5) The priority level must be user-selectable by 
switches and asserted by open-collector drivers 
on bus lines DMA3*-DMAO*. 

The most significant bit of the priority level (ap- 
pearing on DMA3*) must be compared with the 
priority asserted. If the line is asserted low but 
not by this temporary master, allless significant 
priority bit assertions must be removed. 
Similarly, bits DMA2*, DMAI*, and DMAO* 
must be examined and possible less significant 
conflicting bits removed. 

Ifnolines areasserted low except those asserted 
by this temporary master after sufficient set- 
tling time, this temporary master has highest 
priority and may take the bus when pHLDA 
rises. 

Logic implementations must be such that set- 
tling of the arbitration circuitry and bus will be 
completed between the assertion of HOLD* and 
the rise of pHLDA. 


6 


= 
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2.9 Interrupt protocol 


The purpose of an interrupt system is to allow 
peripheral devices to suspend the operation of a bus 
master in an orderly way and to request that the 
master service the requesting peripheral. When ser- 
vice is complete, the bus master returns to the opera- 
tion from which it was interrupted. 

The interrupt protocol is comprised of an 8-level 
vectored interrupt system and a non-maskable inter- 
rupt. A complying master need only implement 
INTS; 


2.9.1 Vectored interrupts 


2.9.1.1 Vectored interrupt requests 


Eight levels of vectored interrupt requests are 
issued оп the vectored interrupt lines, У10* thru 
VI7*, where VIO* is the most significant interrupt 
priority level. Vectored interrupt requests, however, 
may be rotated, masked individually, or ‘‘fenced out" 
by the interrupt control slave, and hence the priority 
levels are not fixed. Requests on the VI lines should 
be asserted as levels, that is, they should be held ac- 
tive until service is received. A slave which asserts a 
УТ line need take no further action to generate an іп- 
terrupt. It is assumed that if interrupt acknowledge 
cycles occur, an interrupt controller somewhere in the 
system will respond appropriately. 

The generalized interrupt request line, INT*, is im- 
plemented as a communication line between the inter- 
rupt controller and an interruptable master. Any 
slave or interrupt controller, using the INT* line, 
must respond appropriately to any interrupt ac- 
knowledge cycles. The interrupt controller is not re- 
quired to use INT*. A vectored interrupt may occur 
without INT* ever being asserted. 


2.9.1.2 Interrupt acknowledge 


The interrupt acknowledge cycle is a standard bus 
read cycle. The interrupt acknowledge cycle requests 
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vectoring information from the interrupt controller 
to be asserted on the data bus during pDBIN. 

Since no address information is asserted during an 
interrupt acknowlege cycle, only one interrupt con- 
troller may exist on the bus. If multiple interrupt con- 
trollers exist, they must either be ‘‘daisy chained” to 
avoid possible bus conflicts, or polled by the bus 
master. 


2.9.2 Non-maskable interrupt (NMI*) 


The non-maskable interrupt is an optional control 
input to bus masters. This interrupt is not maskable 
by a software instruction, and takes priority over 
other interrupt requests. The NMI* line may be used 
in the implementation of the special condition 
lines, ERROR* and PWRFAIL*. 

NMI* is an open collector line. Тһе bus master shall 
respond to negative going transitions on the NMI* 
line. 


2.10 Special condition lines 


Two special condition lines, PWRFAIL* and 
ЕККОК“, are available on the bus. Their use is ор- 
tional. 


2.10.1 Power-fail pending (PWRFAIL:*) 


This line indicates an impending system power 
failure. It is specified that this line shall be activated 
at least 50 msecs before the local voltage regulators 
drift out of specification. 

Тһе line stays low until the power-on clear signal is 
activated. This implies that either a normally closed 
relay or a battery powered circuit drive the power fail 
line. The circuit driving this line must meet the elec- 
trical specifications for an open collector line. 


2.10.2 ERROR* 


This is a generalized error line that indicates that 
the current bus operation is producing an error of 
some sort (i.e. memory parity error, write to pro- 
tected memory, inability to accommodate 8-bit 
slaves, etc.) 

The ERROR* line should be implemented as a trap. 
All relevant information about the error-causing 
cycle—address, data, status, device number (for tem- 
porary masters)—should be latched on the falling 
edge of ERROR*. 

ERROR* is implemented as an open collector line. 


3.0 Electrical specifications 
3.1 Application 


This section defines the electrical specifications for 
interface devices to be used in S-100 bus systems. 
Proper operation of these devices also depends on two 
other factors: 


1) Short physical distance between devices. 
2) Relatively low electrical noise. 
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The electrical specifications for the bus driver and 
receiver circuits do not imply a particular technology, 
unless otherwise noted. 

АШ specifications apply over the temperature 
range T, = 0?C to 70°С. 


3.2 Power distribution 


Power in S-100 systems is distributed as unregu- 
lated DC power at three voltages, +8 volts, +16 
volts, and —16 volts. Because these voltages are on 
adjacent lines it is relatively easy to short these lines 
on card removal. Therefore, bleeder resistors or other 
constant loads sufficient to discharge all three sup- 
plies rapidly are recommended. 


3.2.1 +8 volt specification 


Instantaneous minimum must be greater than +7 
volts, instantaneous maximum less than 25 volts, 
and average maximum less than 11 volts. 


3.2.2 +16 volt specification 


Instantaneous minimum must be greater than 14.5 
volts, instantaneous maximum less than 35 volts, 
and average maximum less than 21.5 volts. 


3.2.8 —16 volt specification 


Instantaneous maximum must be less than —14.5 
volts, instantaneous minimum greater than —35 
volts, and average minimum greater than —21.5 
volts. 


3.3 General signal discipline 


Other than the power lines noted above, all signals 
on the bus are limited to positive signal levels be- 
tween 0 volts and +5 volts, and may not have loaded 
rise or fall times less than 5 nsecs. 


3.4 Driver requirements 
3.4.1 Driver types 
Three types of bus drivers are defined: 


1) Anactive driver, either in the high state or in the 
low state or in transition, which has the capabili- 
ty to accept current in the low state and to pro- 
vide current in the high state. 

Anopen collector driver, which will not accept or 
provide current in the high state. A 10009 + 5% 
pullup resistor to +5 volt or equivalent must be 
provided somewhere in the system for open col- 
lector lines. It is recommended that these pullup 
resistors be provided on the bus. However, im- 
plementation on the permanent master is also 
acceptable. 

A Tri-State driver, which hasthe capability to be 
inthe high-impedance state as wellasinthe high 
and low states. 


2 


-- 


3 


COMPUTER 


3.4.2 Driver specifications 


Specifications for bus drivers shall be as follows: 


Output voltage less than or 
equal to +0.5 volts at 24 mA 
sink current. 

Output voltage (for active and 
Tri-State drivers) greater than 
or equal to +2.4 volts at 2 mA. 


Low state (Уо): 


High state (Мон): 


The leakage current for Tri-State drivers in the 
high-impedance state is specified as not greater than 
+25 pA. 

The internal capacitive load of a driver shall not ex- 
ceed 15 pF at 25°C whether in the active or the high- 
impedance state. 

The rise and fall times of bus drivers should be 
minimized, subject to 3.3. In no case should the rise or 
fall times exceed 50 nsec at rated capacitive load. 


3.5 Receiver specifications 


The specifications for receivers on the bus shall be 
as follows: 


Low state: А voltage less than or equal to --0.8 
volts shall be recognized as a low 
state. 

Highstate: А voltage greater than or equal to 


+2.0 volts shall be recognized as a 
high state. 


Bus receivers shall source no more than 0.5 mA at 
0.5 volts and sink no more than 50 „А at 2.4 volts. 

Busreceivers shall have diode clamp circuits to pre- 
vent excessive negative voltage excursions. 

Additional noise immunity is afforded by the use of 
Schmitt-type receiver circuits. Recommended hys- 
teresis for such receivers should be greater than or 
equal to 0.4 volts. 


3.6 Bidirectional signals 


Some interface signals, such as the data bus, are 
combined Tri-State drivers and receivers. For each 
function these devices must meet the same specifica- 
tions as separate drivers and receivers. 

The total internal capacitive load for a line trans- 
ceiver shall not exceed 20 pF at 25°С. 


3.7 Card-level bus loading 


At the card level, the following specifications ap- 
ply: 


1) The total capacitive load on any bus input shall 
not exceed 25 pF. 

2) A card may not source more than 0.5 mA at 0.5 
volts nor sink more than 80 pA at 2.4 volts on any 
signal line except for DMA0*, DMA1*, DMA2*, 
DMA3*, PHANTOM*, and PWRFAIL*. On 
these lines a card may not source more than 0.4 
mA at 0.5 volts. 
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3.7.1 Bus termination 


АП bus lines except the power and ground lines 
may be terminated to reduce bus noise using a circuit 
equivalent to 


BUS LINE R 


where V —2.6 volts + 0.2 volts and R is no less than 
1809(+ 5%). 

Open collector lines may have a combination pullup 
and termination scheme using a circuit equivalent to 


where V —2.6 volts + 0.2 volts, К, = 1.5KQ + 5%, and 
R, should be no less than 1809 (2-540). 


3.8 Read cycle timing specification 

Figure 11a depicts the read cycle timing waveforms 
with the pertinent timing parameters shown. Table 4 
specifies these parameters. 
3.9 Write cycle timing specification 

Figure 11b depicts the write cycle timing waveforms 


with the pertinent timing parameters shown. Table 4 
specifies these parameters. 
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Figure 11a. Read cycle timing diagram. 
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3.10 Ready and sixteen request timing specification 

Figure 12 depicts RDY, XRDY, and SIXTN* tim- 
ing waveforms during read and write cycles, with per- 
tinent timing parameters shown. Table 4 specifies 
these parameters. 


3.11 Bus transfer timing specification 


Figure 8 depicts bus transfer timing waveforms 
with the pertinent timing parameters shown. Table 5 
specifies these parameters. 


4.0 Mechanical specifications 
4.1 Application 


This section defines the mechanical specifications 
for standard interface sy stems. 


4.2 Connector type 


The card edge connector is a 100-pin (dual 50) con- 
nector with contacts spaced on 0.125" centers. It is 
nominally designed for printed circuit boards 0.062" 
thick. 

Тһе connector is subject to the specifications in 
4.2.1 and 4.2.2. 


4.2.1 Electrical considerations 
1) Voltage rating: 200 volts DC, minimum pin to 
pin. 
2) Current rating: 2.5A per contact. 
3) Contact resistance: 50 mQ maximum at rated 


current after 100 insertions. 
4) Insulation resistance: 1000 М9 minimum. 


4.2.2 Connector spacing 


Connectors should be spaced 0.75 inches —0.01 in- 
ches center to center. 
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Figure 11b. Write cycle timing diagram. 


Table 4. Read/write cycle timing parameters. 
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Ф PERIOD 

Ф PULSE WIDTH HIGH 

Ф PULSE WIDTH LOW 

DELAY Ф HIGH TO pSYNC HIGH; 


DELAY Ф LOW TO pSYNC LOW 
pSYNC PULSE WIDTH HIGH 


pSTVAL* LOW PRIOR TO Ф LOW DURING pSYNC 

pSTVAL* PULSE WIDTH HIGH 

pSTVAL* PULSE WIDTH LOW 

pSTVAL* FALLING EDGE PRIOR TO pSYNC HIGH 

ADDRESSES STABLE PRIOR TO pSTVAL* LOW DURING pSYNC HIGH 
STATUS STABLE PRIOR TO pSTVAL* LOW DURING pSYNC HIGH 
pDBIN PULSE WIDTH HIGH 

DELAY pSTVAL* LOW TO pDBIN HIGH 

DELAY pDBIN LOW TO pSYNC HIGH 

HOLD TIME FOR ADDRESSES AND STATUS AFTER pDBIN LOW 
DELAY pDBIN LOW TO SLAVE DI DRIVERS Hi-Z 

DELAY pDBIN HIGH TO SLAVE DI DRIVERS ACTIVE 

DELAY pSTVAL* LOW TO DATA VALID 


DATA VALID SETUP TIME TO pDBIN LOW 
pWR* PULSE WIDTH LOW 

DELAY pSTVAL* LOW TO pWR* LOW 
DELAY pWR* HIGH TO pSYNC HIGH 
SETUP TIME DO VALID TO pWR* LOW 


HOLD TIME ADDRESSES, STATUS, AND DO FROM pWR* HIGH 

DELAY pWR* LOW TO MWRT HIGH; DELAY pWR* HIGH TO MWRT LOW 
SETUP TIME RDY, XRDY, SIXTN* TO Ф RISING 

HOLD TIME RDY, XRDY, SIXTN* AFTER Ф RISING 


MIN.(NSECS) 


166 
0.4tgy 
0.4tgy 
10 


0.7tey 


10 


MAX.(NSECS) 
2000 


0.46у 


25+0.1tçy 
25 4- 0.1tey 


SPECIFIED BY MANUFACTURER. 
WORST CASE MAXIMUM FOR ALL 
SLAVES AND WORST CASE 
MINIMUM FOR ALL MASTERS. 


0.9еу 
30 

0 
Ottey 


0.24, 


80 
70 


30 
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ВрҮ, XRDY, SIXTN* ШЕ 


fSIXTN* is sampled only during pSYNC 
RDY and XRDY are sampled when pSYNC 
= F only if the master is in a wait state. 


Figure 12. Timing of RDY, XRDY, and SIXTN* during read and write cycles. 


Table 5. 
Bus transfer timing parameters. 

tset DELAY pHLDA TO ADSB*, SDSB*, DODSB* 30 1 
loy TIME BOTH TEMPORARY AND PERMANENT MASTER DRIVE THE CONTROL 

OUTPUT LINES 0.5їсү 
Inm HOLD TIME ADDRESS, STATUS, AND DATA OUT DURING DMA CYCLE 0.2toy 
tne, SETUP TIME, END OF BUS TRANSFER TO pHLDA RISING EDGE 20 

4.3 Board size specification shownin the figureis pin 50. Pin 100 opposes pin 


50 on the back side of the board. 
Circuit boards shall conform to the board size speci- Total board depth shall not exceed 0.65 ". 


fications given in Figure 13. The edge connector pin Nominal board thickness is 0.062”. 
0.080 
5.125 МАХ. 0.500 MAX. 007 
0.245 
@ 255 0.125 MIN. 0.125 МАХ. 0.740MIN. 
Lo 1 
T 2.14. 
2.130 


0.005 МАХ. MISALIGNMENT OF 
CARD GUIDES RELATIVE TO 
CONNECTOR CENTER LINE 


p. 


CENTER LINE OF PIN 50 


50 POSITIONS 
0.125 SPACING 


CHAMFER FINGERS— 
0.015 x 45° 

BREAK ALL SHARP 
0.125 


CORNERS | 
6.365 
6.375 
0.135 


- —— ^r^" 
4 5 BOARD THICKNESS 
0.325 0.062 А m т NOMINAL 


GENERAL DIMENSIONS COMPONENT CLEARANCE— BACKPLANE DIMENSIONS 
TOP VIEW 
Figure 13. S-100 board mechanical parameters. 
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SW3LSASOHOIW 001-5 


Sb 


Birmingham 
Canoga Park 
Fresno 
Hawthorne 


Huntington Beach 


Lawndale 

Long Beach 
Los Altos 

Los Angeles 
Marina Del Ray 
San Diego 

San Diego 

San Diego 

San Diego 

San Fransisco 
Santa Clara 
Signal Hills 
Pasedena 
Westminster 


Washington 
Washington 


Destin 
Miami 
Tampa 


Atlanta 
Atlanta 
Atlanta 
Atlanta 
Augusta 


Chicago 
Chicago 
Chicago 
Joliet 


Olathe 
Wichita 
Boston 


Maynard 
Dunstable 


Parkville 
Silver Springs 
SEMCO 

Westland 


Grosse Pointe 
Grosse Pointe 


Birmingham Microcomputer Group 
San Fernando Valley ABBS 
California CBBS 

Hawthorne ABBS 

Kors-Meyer Electronics ABBS 


Computer Components Assoc of Orange County 


Homebrew Computer Club 
San Fernando CBBS 


Apple Corps of San Diego(Computer Merchant). 
Bill's ABBS (Peoples Message System) 


Stan Skoglund (Infobit) C BBS 
San Diego Computer Society CBES 


Peripherals Unlimited Inc. ABES 
Pasedena С BBS 


Computer Components Assoc of Orange County 


Washington DC CBBS 
Program Store Forum 80 


Ft. Walton Beach ABBS 
South Florida Computer Group CBES 
Tampa Forum 80 


Northstar CBBS 

Atlanta Computer Society CBES 
Atlanta CBBS 

Microstuff Inc CBES 

Augusta Forum 80 


Personal Computers of Chicago 
Ward & Randy's Chicago CBES 
Forum 80 of Chicago 

Wayne Jupiter CBBS 


Engineer 80 - Forum 80 
Forum 80 


New England Computer Society CBBS 
NECS/DEC CBBS 
Forum 80 


Muse Со. 
WB3ETS Е 


SEMCO СВВ ~ Macomb county 
SEMCO CBBS - Westland 

SEMCO CBBS - 300 baud only 
SEMCO CBBS - 110 baud only 


-942-6621 
213-340-0135 
209-638-6392 
213-675-8803 
714-964-4346 
213-3 70-31 60 
213-428-4718 
415-948-1474 
213-843-5390 
213-8 21-7369 
714-58 2-9557 
714-449-5689 
714-565-0761 
714-571-5550 
415-668-4246 
408-246-2805 
213-424-3506 
213-795-3788 
714-898-1984 


703-281-2125 
202-337-4694 


904-243-1257 
305-821-7401 
813-223-7688 


404-939-1520 
404-394-4220 
404-458-4886 
404-325-0526 
803-279-5392 


312-337-6631 
312-528-7141 
312-925-0259 
815-727-7069 


913-764-1520 
316-746-2078 


617-864-3819 
617-897-0346 
617-649-7097 


301-661-8962/3 
301-593-3042 


313-286-8820 
313-326-6020 
313-343-2375 
313-343-2370 


8AM-5PM Ө ЗОО baud 


7: 1БАМ-11 PM 


6:30-8 : ЗОРМ 


evenings 


110 baud only 


24 hours 


6PM-7AM & weekends 


code; НЕ -К9О1, SEMCO 


SWALSAS ачуоя NILATING Ча4714Ч4104МОЭ 


L1 әбей шош рәпицио> 


9% 


SWS3LSASOHOIW 001-5 


Kansas City 


Kansas City CBBS - EMS 


MO Kansas City Kansas City Forum 80 

MO St. Louis St. Louis Forum 80 

NE Las Vegas Las Vegas Forum 80 

NJ Bound Brook SJ Electronic Mail Center 

NJ Piscataway ACG-NJ Apple User Group АВВ5 
NJ Piscataway ACG-NJ Apple User Group ABES 
NJ Marlton Johnathan's Apple Store ABES 
NJ Princeton Princeton Forum 80 

NY New York Long Island ABES 

OH Akron Digital Group C BBS 

OR Beaverton Northwest CBBS 

TX Dallas Dallas CBBS 

TX Dallas Dallas Forum 80 

TX Dallas KA Electronics ABBS 

TX Dallas Computer Hobbyists Group of N Texas CBBS 
TX Fort Worth Fort Worth Forum 80 

TX Fort Worth CHG-NT CBBS 

TX Houston Houston ABES 

TX San Antonio Appleseed ABBS 

TX Witchita Falls Forum 80 

VA Falls Church North Star CBES 

VA Falls Church Virginia Business Systems 

VA Mc Lean Paul's ABBS 

VA Fairfax Family Historians Forum 80 
VA Vienna AMRAD C BBS 

WA Pugetsound Washington ABBS 

TN Memphis Memphis Forum 80 


Fort Lauderdale area with ASCII on 
229 MHz and 400 MHz. 
The list of CBBS's across the 


country is growing. 


Some are dying out 


816-737-1031 
816-861-7040 
314-838-7784 


702-873-9112 


201-457-0893 
201-968 -1074 
201-753-1225 
609-983-5970 
201-874-6833 


212-448-6576 
216-745-7855 
503-646-5510 


214-641-8759 
214-288-4859 
214-634-2775 
214-268-6495 
817-923-0009 
817-268-6445 
713-977-7019 
512-657-0779 
817-855-3916 


703-734-1387 
703-533 -8 591 
703-893-WA4RI 
703-978 -7561 
703-281-2125 


206-524-0203 
901-276-8196 


FO80 
FOBO 


FOBO 5-9PM 


6800 code:HEL-I999,MAIL 
A BBS 
А BBS 
А BBS 
FO80 


AB BS 


CP/M 
ЕОВО 
A BBS 


FO8O 


АВВ5 
АВ ES 
F080 


CP/M 
ABES 
A BBS 
ЕОВО 
6800 Ham Radio Link 


ABBS 24 hours 
FOBO Handicapped Appl; 


CBBS CODES USED: 
CBBS TYPE: 


after a short existance, but for every 
one that folds, there are at least three 
new ones to take it's place. The 
following is a list of some of the 
CBBS's and no doubt there are many more 
that I am not aware of. We will reprint 
and updated directory of CBBS systems 
periodically. So if you or your club 
has a CBBS system that you would like to 
have listed send me the information care 
of S-100 MICROSYSTEMS. 


CP/M - indicates а 
AEBS - indicates a 
FOSO - indicates а 
6800 - indicates a 


Notes: 
additional notes are given 
hand column. 
which is listed there. 


CBBS using а CP/M system 
CBBS using an Apple system 
CBBS using а TRS-80 system 
CEBS using a 6800 system 


in the extreme right 
Some CBBS's re uire а password 


HARDWARE 


SOFTWARE 


HI THERE! 


It has come to our attention that many of our customers are not aware 


of the wide variety of products we have available. 


Following is 


of all our current major products and prices. 


Part No. 


MEM-32K-ASM 
MEM-16K-ASM 


CI-ASM 
CI-KIT 
FDI-ASM 
FDI-KIT 
DD-ASM 
DD-KIT 
VDS-II 
VDS-IID 
PS270 
SIM120 
SHU800 
CP272 
CP206 
CP206 


TBAS-CAS 
TBAS-DSK 


TBAS-LST 
TBAS-SRC 
PTSW+LST 
EMPL-CAS 
EMPL-DSK 
CPM-2.0 
CPM-1.4 
CPM-1.4-M 
CPM-MS 
BASE-MAN 
BASE-LST 
PBLC-DMN-1 


PBLC-DMN-2 


CBAS-DSK 
CBAS-MAN 
SPLR 

FAST 
TELE-COM 
POLYVUE 
PASCAL/MT 


Description 


Tarbell 32k Static Memory for S-100 bus 
Tarbell 16k Static Memory for S-100 bus 
(Memories only come assembled & checked out) 
Cassette Interface Assembled & Checked out 
Cassette Interface Kit 

Floppy Disk Interface Assembled & Checked out 
Floppy Disk Interface Kit 

Double Density Floppy Disk Interface АКТ 
Double Density Floppy Disk Interface Kit 


Vertical Disk Subsystem l 
Double Density Disk Subsystem 1 
PerSci Model 270 Dual Floppy Disk Drive 1 


Siemens Model 120-8 Single Floppy Disk Drive 
Shugart 800/801 Floppy Disk Drive 

Power Supply for PerSci 270 Dual Drive 

Power Supply for PerSci 299 

Power Supply for Two Siemens or Shugart 


Tarbell Cassette BASIC on cassette incl manual 
Tarbell Disk BASIC on CP/M disk incl manual 
Note: the following two items can only be 
ordered with Tarbell Disk or Cassette BASIC: 
Тагре11 BASIC source listing on paper 

Tarbell BASIC source on 2 CP/M disks 

Proc Tech Assembler/Editor with listing 

EMPL micro APL on cassette & instructions 

EMPL micro APL on CP/M disk & instructions 

CP/M 2.0 Operating system incl documentation 
CP/M 1.4 Operating system incl BASIC-E on disk 
CP/M 1.4 on soft-sectored MINI-FLOPPY disk 

CP/M 1.4 Operating system manual set (of six) 
BASIC-E Compiler Manual (works with CP/M) 
BASIC-E Source Listing (in PL/M) 

Public Domain Disk #1 - includes DISKTEST, 
BASIC-E, CBIOS, FORMAT, TAPELIB, etc or. disk 
Public Domain Disk #2 - includes Double Density 
FORMAT, DISKTEST, Auto-BIOS for 1.4 & 2.0; FORTH 
CBASIC-2 disk 

CBASIC-2 manual 

KLH Systems Spooler for CP/M on disk 

FAST! Screen-oriented Editor/Assembler for CP/M 
Software to operate D.C. Hayes Modem Remote 
Screen-Oriented CP/M Editor 

Meta-Tech Pascal Compiler for CP/M 


Prices are subject to change without notice. 
California residents please add 6$ sales tax. 
For quick deiivery, see your local Tarbell dealer. 


(213) 538-4251 


2 950 Dovlen Place, Suite В 
Carson, California 90746 


(213) 538-2254 


a list 


Price 


725.00 
440.00 


175.00 
120.00 
265.00 
190.00 
425.00 
325.00 
888.00 
999.00 
295.00 
495.00 
525.00 
125.00 
120.00 
120.00 


48.00 
48.00 


25.00 
25.00 
15.00 
15.00 
20.00 
150.00 
70.00 
70.00 
25.00 
5.00 
15.00 


10.00 


15.00 
85.00 
15.00 
70.00 
100.00 
195.00 
135.00 
99.95 


АМ 8080 DISASSEMBLER 


by 


William Yarnall 


ACG-NJ 


1176 Raritan Rd. 
Scotch Plains, NJ 07076 


A Disassembler program will take object code, in RAM, 
and yield a source code output. It is an invaluable 


Software utility. 


This Disassembler program takes up only 


1К of memory space and is very easy to use. 


This is a very simple and easy to 
use disassembler program than can be 
used with virtually any 8080 
microcomputer system. Previous to my 
getting disks I used it with my audio 
cassette based system. Т now use it on 
my IMSAI with North Star Disk System, in 
both CP/M and North Star DOS. 

I have several versions on disk 
that are assembled to run at different 
memory locations. For North Star DOS I 
have versions that are assembled to run 
at 0, 2A00H, 5800H and р000Н. For CP/M 
I have versions assembled to run at 
100H, 5800H and DOOOH. I then load the 
appropriate version for the software I 
am going to disassemble. For example, 
to disassemble North Programs that have 
an origin of 2A00H, I load and run the 
disassembler at memory location O. To 
disassemble a CP/M program that has an 
origin at 100H, I load and run the dis- 
assembler in high memory (e.g. 5800H or 
D000H depending on where CP/M is 
located). 

The version of disassembler shown 
here is set up to run with my monitor 
program that starts at Е000Н. Therefore 
the program starts with "global definit- 
ions" that define the locations of the 
console (keyboard and VDM display in my 


A>DIR 

A: NSTAT COM 
A: ZDIR COM 
A: ED COM 


A: DISASM PRN 

A: DISASM ASM 
A>TYPE DISASM.ASM 

; GLOBAL DEFINITIONS 


INP EQU 0ЕО92Н ; KEYBOARD INPUT 
OUT8 EQU 0Е17СН ; CHARACTER DISPLAY 
EEND EQU 0ЕО2ВН ; RETURN TO MONITOR 
ORG 0 
48 
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case) I/O driver routines and the return 
address for the monitor or operating 
system. These equates should therefore 
be changed to suit your particular DOS 
or monitor program. 

Routine LOOP, near the beginning of 
the program reads the sense switches on 
the front panel of my IMSAI-8080. If 
switch 2 is raised then the disassembly 
is interrupted and control is returned 
to the operating system. This allows me 
to interrupt a run at any point before 
the run is completed, should I desire to 
do so. If your system does not have a 
front panel with sense switches and you 
want to be able to interrupt a run then 
replace the IN OFFH and ANI 2 in- 
structions with a CALL to the keyboard 
status routine followed by a jump to the 
operating system. Then any keypress 
will interrupt execution and return to 
the operating system. This works if the 
keyboard input routine returns with a 
non-zero. If it returns a zero change 
JNZ EEND to JZ EEND. 

To use the disassembler program 
load it into memory and then type the 
Starting address of the memory area to 
be disassembled followed by a comma and 
the ending address to be disassembled. 


MAIN PROCESSING LOOP 
GET STARTING ADDRESS 


LXI H,0 
GINO: PUSH Н 
CALL INP ; GET KEYBOARD CHAR 
CALL OUT8 ; ECHO 
CALL NYBLE 
POP H 
JC GIN1 
MOV E,A 
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МУІ р,0 
рАР Н ЇМХ Н 
рАР Н RET 
DAD H ; 4-СНАВ MNEMONIC 
DAD H CRD2: INX H 
DAD D MOV A,M 
JMP GINO LXI H,TBX 
GIN1: XRA A CALL ADDH 
XCHG MOV A,M 
LOOP: IN ОЕЕН р SENSE SWITCH INX H 
ANI 2 ; NO. 2 TO QUIT JMP CRDO 
JNZ EEND ; RETURN TO MONITOR ; CHECK FOR REG "PSW" 
CALL CLER CHEK: CPI ОЕ1Н 
CALL PROC 72 СНЕКО 
CALL DISP CPI ОЕ5Н 
JMP LOOP RNZ 
; CONVERT ASCII TO HEX CHEK0: LXI H,'SP' 
NYBLE: CPI "0! SHLD PARG 
RC MVI A,'Ww' 
CPI 'Е'+1 5ТА РАВС+2 
смс ВЕТ 
RC ; INITIALIZE OUTPUT BUFFER 
SUI to! CLER: LXI H, PLOC 
CPI 10 MVI B,36 
CMC CLERO:  MVI М," ' 
RNC INX H 
SUI 7 DCR B 
CPI 10 JNZ CLERO 
RET MVI M,13 
; ADD (A) TO H,L ; CONVERT & STORE PC 
ADDH: ADD I. PUSH D 
MOV L,A POP H 
RNC LXI B,PLOC 
INR H CALL C4D 
RET ; CONVERT & STORE COMMAND 
; GET AND STORE MNEMONIC LDAX D 
; (HL) POINTS TO MNEMONIC TABLE MOV H,A 
CARD: PUSH H LXI В,РС1 
МУІ Ау?" CALL C2D 
CRDO: STA РММЕ-3 ВЕТ 
MOV A,M ; GET AND STORE ARGUMENT 
ORA A ; (HL) POINTS TO PROCESS BYTE 
JZ CRD2 CREG: MOV A,M 
MOV В,А RLC 
RRC JNC CR1 
RRC ; REGISTER PAIR ARGUMENT 
RRC PUSH PSW 
ANI 1ЕН LDAX D 
ADI 40H ANI 30H 
STA PMNE RRC 
INX H RRC 
MOV C,M RRC 
MOV A,B RRC 
ANI 7 LXI H,REGI 
RLC CALL ADDH 
LC MOV A,M 
MOV B,A STA PARG 
MOV A,C LDAX D 
RLC CALL CHEK 
RLC POP PSW 
ANI 3 CR1: RLC 
ORA B JNC CR3 
ADI 40H ; SINGLE REGISTER ARGUMENT 
STA PMNE+1 PUSH PSW 
MOV A, iC LDAX D 
ANI 1FH CPI 40H 
27 CRD1 JNC CR6 
ADI 40H ANI 38H 
STA PMNE+2 RRC 
CRD1: POP H RRC 
INX H RRC 
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СВ2: LXI H,REG2 
CALL ADDH 
MOV A,M 
STA PARG 
POP PSW 
CR3: RLC 
JNC CR7 
; 1-ВУТЕ CONSTANT ARGUMENT 
INX D 
LDAX D 
MOV H,A 
PUSH H 
LXI В,РАВС-2 
CALL C2D 
POP H 
CR3A: LXI B,PC2 
CALL C2D 
Сва: ГОА РАВС 
СРІ voa 
22 CR5 
MVI By! Vit 
STA РАВС+1 
СВ5: CALL JUST 
RET 
CR6: ANI 7 
JMP CR2 
CR7: RLC 
JNC CR8 
; 2-BYTE CONSTANT ARGUMENT 
INX D 
LDAX D 
MOV уд 
INX D 
LDAX D 
MOV H,A 
PUSH H 
LXI B ,PARG-42 
CALL C4D 
POP H 
LXI B,PC3 
CALL C2D 
JMP CR3A 
CR8: LDAX D 
; TEST FOR "RST" AS SPECIAL CASE 
ANI 0С7Н 
СРІ 0С7Н 
JNZ CR5 
LDAX D 
ANI 38H 
RRC 
RRC 


My" 


8086 Boaras 


CPU with $650. 
Vectored Interrupts 


PROM-I/O $495. 
RAM $395. 


8K x 16/16K x 8 


50 


ANALOG Boards 


A/D 16 Channel, $495. 


12 Bit, High Speed 


D/A 4 Channel, $395. 


12 Bit, High Speed 


RRC 


ADI о! 

STA PARG 

RET 
; LEFT JUSTIFY ARGUMENT FIELD 
JUST: ТРА PARG 

CPI '5' 

22 1082 

СРЇ . 

RNZ 

LDA PARG42 

CPI ба 

в2 
; LEFT SHIFT FIELD BY 2 

PUSH B 

PUSH D 

PUSH H 

PUSH PSW 

LXI H,PARG 

LXI D, PARG+2 

MVI B,6 
JUSO: LDAX D 

MOV M,A 

INX H 

INX D 

DCR B 

JNZ JUSO 
JUS1: РОР PSW 

POP H 

POP D 

POP B 

RET 
; MAKE PLACE FOR 1 ADD'L CHAR. 
JUS2: PUSH B 

PUSH D 

PUSH H 

PUSH PSW 

LXI H, PARG+6 

LXI D,PARG+5 

MVI B,5 
1083: ТРАХ D 

MOV М,А 

DCX D 

DCX H 

DCR B 

JNZ JUS3 

MVI A,'P' 

MOV М,А 

JMP JUS1 


; CONVERT 1 BYTE TO 2 ASCII CHARS. 


S-100 Boards 


Video and/or Analog 
Data Acquisition 


DIGITIZATION ве 


Real Time Video $850. 
Digitizer and Display 
Computer Portrait 


TECMAR, INC. 
$4950. (216) 382-7599 


5-100 MICROSYSTEMS 


Microcomputer Systems 


The High Performance S-100 People 


23414 Greenlawn е Cleveland, OH 44122 


С20: PUSH D 
MVI р,„2 
ОМР CVD 


; CONVERT 2 BYTES TO 4 ASCII CHARS. 


C4D: PUSH D 
MVI D,4 

CVD: XRA A 
DAD H 
RAL 
DAD H 
RAL 
DAD H 
RAL 
DAD H 
RAL 
CPI 10 
JC CVDO 
ADI 7 

суро: АРТ "0: 
5ТАХ B 
INX B 
DCR D 
JNZ CVD 
POP D 
RET 

; DISPLAY LINE 

DISP: PUSH H 
LXI H,PLOC 

DISPO: MOV A,M 
CALL OUT8 
CPI 13 
JZ DISP1 
INX H 
JMP DISPO 

DISP1: РОР H 
RET 


; PROCESS COMMAND (DE POINTS TO COMMAND) 
PROC: PUSH D 


LDAX D 
CPI 40H 
JNC PRB 

; COMMAND 00 - 3F 
ANI 7 
RLC 
MOV CA 
RLC 
ADD C 
LXI H,PRA 
CALL ADDH 
PCHL 

PRA: LXI H,TB1 
JMP PRA4 
LXI H,TB2 
JMP РВА5 
LXI H,TB3 
JMP РВА1 
LXI H,TB4 
JMP РВА5 
LXI Н,ТВ5 
JMP PRA3 
LXI H,TB6 
JMP PRA3 
LXI H,TB7 
JMP PRA3 
LXI H,TB8 

РВА1: LDAX D 
ANI 38H 
RRC 
RRC 
MOV С,А 
ВВС 
ADD e 


$-100 MICROSYSTEMS 


PRA2: 


PRA3: 


PRA4: 


PRA5: 


PRB: 


; COMMAND 40 


; MOV INSTRUCTION 


PRC: 


; COMMAND 80 


; COMMAND CO - FF 


PRD: 


; REGISTER TABLES 


REG1: 


REG2: 


CALL ADDH 
CALL CARD 
POP D 
CALL CREG 
INX D 
RET 
LDAX D 
ORA 
JZ PRA3 
MVI A,3 
JMP PRA2 
LDAX D 
ANI 8 
TZ PRA3 
MVI Ave 
JMP PRA2 
CPI 80H 
JNC PRC 
7F 
LXI H,TB9 
LDAX D 
CPI 76H 
JZ PRA3 
LXI H,'OM' 
SHLD PMNE 
LXI н," у" 
SHLD РММЕ-2 
АМТ 38H 
RRC 
RRC 
RRC 
EXT H, REG2 
CALL ADDH 
MOV L,M 
MVI MUN 
SHLD PARG 
LDAX D 
ANI 7 
LXI H,REG2 
CALL ADDH 
MOV A,M 
STA PARG+2 
POP D 
INX D 
RET 
CPI осон 
JNC PRD 
- BF 
LXI Н,ТВ10 
JMP РВА1 
SUI осон 
моу QA 
RLC 
ADD C 
LXI Н,ТВ11 
JMP PRA2 
DB 'в' 
рв то! 
рв 'н' 
рв 5" 
DB 'B' 
DB "С" 
рв 'p! 
DB ҮЕ" 
DB 'B' 
DB "pi 
DB 'м' 
рв "A! 
54 


СОМТА 


ТВ2: 


ТВ3: 


ТВ4: 


TB5: 
TB6: 
TB7: 


TB8: 


TB9: 


TB10: 


52 


COMMAND PROCESSING TABLES 


TBLIS 


INS MNEMONICS & PROCESSING FLAGS 


0D073H 
0 
922CH 
0 
966H 
90H 
4420H 
80H 

0 

80H 
300H 
80H 

0 

80H 
300H 
80H 
600H 
10H 
900H 
10H 
19DH 
тон 
161Н 
10Н 
984ВН 
80H 
0D820H 
80H 
924BH 
40H 


continued on page 56 


DW 9A93H 
DB 0 

DW 0D083H 
DB 80H 

DW 9A53H 
DB 10H 

DW 5053H 
DB 10H 

DW 9A1BH 
DB 10H 

DW OC OOH 
DB 80H 

DW 909H 
DB 20H 

DW 00494Н 
ОВ 0 

DW 8096H 
DB 0 

DW 5491H 
DB 0 

ри 8056Н 
ОВ 10Н 

DW 922CH 
DB 0 

DW 801ЕН 
DB 10H 

DW ОЕООН 
DB 10H 

DW 0C908H 
DB 20H 

DW 0D494H 
DB 0 

DW 8393H 
DB 0 

DW 0D083H 
DB 80H 

DW 8353H 
DB 10H 

DW 547DH 
DB 20H 

DW 831BH 
DB 10H 

DW OCOOH 
DB 80H 

DW 499DH 
DB 20H 

DW 0D494H 
DB 0 

DW 0C090H 
DB 0 

DW 922CH 
DB 0 

DW 0С050Н 
ОВ 10Н 

DW 804BH 
DB 20H 

DW 0C018H 
DB 10H 

DW 922CH 
DB 0 

DW 8998H 
DB 20H 

DW 0D494H 
DB 0 

DW 0Ғ94Н 
DB 0 

DW 0D083H 
DB 80H 

DW 0Е54Н 
DB 10H 

DW 1200H 


S-100 MICROSYSTEMS 


5М4153Х508О01н 001-5 


са 


ае во во 


REGO 
REGI 
REG2 
REGS 
REG4 
REGS 
REGS 
RESE 
WCCH 
WCLI 
STIM 


СКТІ 


NUMR 
NUMC 
STKT 
ВІЅР 
BLAN 


, 
, 
П 
; 
! 
, 
4 
+ 
i 
и 
, 
, 
, 
, 
, 
, 
1 
! 
, 
E 
И 
? 
К 
Н 
, 
4 
, 
М 
, 
+ 
, 
4 
, 
$ 
, 
, 
, 
, 
4 
D 
, 


«РКОС CRTCTL $ 


, 
VIDEO DISPLAY BOARD CONTROL. SOFTWARE ; 
FOR S.I.SALES УПВ-8024. JON БОМПҮ, 5/16/79 $ 
FORTS ASSIGNED TO REGISTERS INSIDE THE ЗМС 5027 CHIF 
«Езу вон 5НОКТ20МТАГ LINE COUNT 
+EQU 81H 5МОПЕ/НбҮМС WIITH/HSYNC DELAY 
+EQU 82H %5САМ5 РЕК DATA ROW/CHARS FER DATA ROW 
„Ебу 83H 55КЕЫ ЕІТ5/ПАТА ROWS FER FRAME 
»ЕВИ 84H %5САМ LINES FER FRAME 
.EQU 85H *VERTICAL DATA START 
+E QU 86H yLAST DISPLAYED DATA ROW 
T +EQU ВАН %КЕБЕТ 5027 
Ак  .EQU вен ЗИКТТЕ CURSOR CHARACTER/COLUMN АППКЕ55 i 
NE „ЕВО 80H ?ИКТТЕ CURSOR LINE ALLIRESS , 
CH „ЕВО ВЕН %5ТАКТ ТІМІМС СНАЇМ , 
N «EQU 20H 51МРОТ FORT FROM WHICH CHARACTERS 
FROM THE COMPUTER ARE RECEIVED 
OW .EQU 24 *NUMBER OF ROWS 
OL .EQU 80 ;NUMRER OF COLUMNS 
OF EQU 2000H STOF OF STACK 
MEM .EQU 1000H %5ТАКТ OF DISPLAY MEMORY 
K ,EQU 20H 885011 BLANK 
, 
а МОТЕ ОМ ТНЕ 5027 , 
, 
ІМ ORDER ТО SCROLL THE DISPLAY RAPIDLY: THE 5027 DOES NOT MOVE n 


DATA AROUND IN THE DISPLAY MEMORY IN-ORBER TO SCROLL. RATHER? 


IT STARTS READING DATA FOR REFRESH AT à DIFFERENT LOCATION IN 

THE MEMORY; AND ‘WRAPS AROUND” FROM THE BOTTOM ОҒ THE BUFFER TO 

THE ТОР WHEN IT МЕЕП5 ТО, BECAUSE OF THIS USE OF а CIRCULAR 

BUFFER» THE UFFER LEFT CHARACTER ON THE SCREEN NEED NOT ALWAYS 

ВЕ (AND MOST OFTEN IS NOT) THE INITIAL BYTE IN THE REFRESH MEMORY. 

А REGISTER IN THE 5027 IS USED TO KEEF TRACK OF WHERE THE REFRESH 

15 TO STOF (AND HENCE» WHERE IT IS TO START)» амп THE FOLLOWING 

FIRMWARE MUST KEEF TRACK UF THIS IN ORDER THAT IT ALWAYS KNOW WHERE HLT 
THE ТОР OF THE USER'S DISPLAY IS. THIS IS THE MAIN FUNCTION OF THE 

“В” REGISTER» WHICH ALWAYS MAINTAINS а COPY OF THE LAST LINE 


NUMBER WHICH THE 5027 WILL DISPLAY. 


IN THE FOLLOWING CODE» TWO SIMILAR TESTS OCCUR FREQUENTLY» ONE ТО 
SEE IF THE CURSOR HAS MOVED OUTSIDE OF THE BUFF 


A cmo 


К сами HENCE SHOULD 


NIT 


BE MOVED TO THE ТОР OF THE BUFFER IN ORDER TO WRAP ARGUNI)» амп ONE 
TO SEE IF THE CURSOR HAS MOVED OUTSIDE OF THE SCREEN СТ.Е,» BELOW 
THE LAST LINE OR ABOVE THE FIRST LINE). IF THE READER ALLOWS THESE 
TWO TESTS TG BECOME CONFUSED WITH EACH OTHER» THE COLE WILL MAKE NU 
SENSE AT ALL. 


REGISTER USE 


SCRATCH 

LAST DISPLAYED LINE ~- SEE ABOVE DISCUSSION Ом 5027 
SCRATCH 

COLUMN NUMBER FOR CURSOR 

LINE NUMBER FOR CURSOR 


ISPLAY 


HL 


ADER OF NEXT CHAR IN DISF MEMORY 


POWER UF INITIALIZATION 


«ORG 
LI 
IN 


START OF 


+ ORG 
POF 
IN 
BIT 
JP 
BIT 
JR 
БІТ 
JR 


DISPLAY 


LI 
LI 
ІМС 
СР 
JR 
LD 
INC 
INC 
ойт 
SCF 
EI 
HALT 


0 
SF» STKTOF БЕТ UP STACK POINTER 
AsCCRTINO $CLEAR ТЕРТ FLOF 
Ау 30H) &CLEAR КВО REY FLOP 
INIT 55ЕТ UP 5027 CHIF 
CLEAR 55ТАКТ WITH SCREEN CLEARED 
1 $8ET UP INTERRUPT MODE 
З5ЕТ CARRY FLAG -- NO LONGER ИЗЕП z 
ЗЕМАВСЕ IRPTS AND WAIT 5 
INTERRUPT DRIVEN PROGRAM g 
38H 2 
IY $SAVE RETURN ADDRESS < 
А, (СКТТН) 5ЇМРОТ CRT CHAR > 
тъй $18 THIS A CURSOR CONTROL CHAR ? 
NZ»GOXY ;YES C) 
буй $TEST FOR OTHER CONTROL CHARS 
NZ DISPLAY МО -- IIISPLAYABLE CHARACTER -] 
SrA $TEST AGAIN FOR CONTROL CHAR "T 
Z;CTR YES m 
O 
CHARACTER о (2 
= 
eg 
буй $CHAR SAVED IN C REG 5 
бур $PLAY WITH COLUMN COUNTER Е о 
А 518 NEXT CHAR ON SAME LINE ? В. < 
NUMCOL s 
ZiHLT $NOPE a 
CHL 2 РОТ CHAR IN DISPLAY MEMORY 30 
р $CLEAN UF COLUMN POINTER d 
HL $CLEAN UP MEMORY POINTER у 0 
СМССНАК 5 А 9КЕРО5ЇТЇОМ CURSOR ON SCREEN а О 
$MAIT AGAIN ° 5; 
са 
BÓ 


INITIALIZE CRT 5027 CHIF 


(RESET ),А ;SEE 5027 DATA SHEET FOR MEANING OF THESE 
A:06SH 


(REGO ›,А 

А»04ЕН 

(REGI +A 

А»041ІН 

СКЕС22,А 

Ay OD7H 

(REGS ),А 

A»003H % 60 HZ 
CREG4 » 8 

Ay OBH 5 60 Н2 
СКЕб5)»нА 

А? NUMROW- 1 


! 


ОЗН, SO HZ = 1DH 


Ч 


OBH» 50 HZ = 


1 
ы 
сл 
т 


vs 


SW3LSASOHOIW 001-5 


[ad ч се, 


Го» же а» 


Сэ» ee ee 


FCR 


LD 

OUT 
Lu 

OUT 
OUT 
OUT 
OUT 
OUT 
LI 

RET 


LIES 

(REGS ),А 
А,0 
CWCCHAR ›,А 
CWCLINE »А 
(8ТЇМСН»» Өд 
(КЕБЕТ»й 
(8ТЇМСН» А 
ПЕ,0 


SLAST LINE DISPLAYED 


START WITH COLUMN ANI! ROW AT ZERO 


BRANCH ON CONTROL CHARACTERS 


LI IY:HLT 
FUSH IY 

CF 08H 

JF Z:ES 

СР 09H 

JF 2, Так 
СР ОАН 

JF Z:LF 
CF орн 

JF 2, СК 

СР OCH 

JF Z»CLEAR 
СР 011H 

JF ZsUFL INE 
СР 012H 

JF Ze ПМ INE 
СР 013H 

JF Zy RIGHT 
CF 014H 

JF Z:LEFT 
CF 15H 

JF ZsHÜME 
СР O16H 

JF 2?ЕЕ05 
СР 017H 

JF ZsEEOL 
CF OLAH 

JF Z CLEAR 
FOF IY 

JR HLT 
CRLF 

CALL LF 

CALL CR 

LINE FEEL 

п бэЕЁ 

СР Е 

CALL. Z»SCRUF 
INC А 

СР NUMR OW 
JR М2, ЕКТ 
LI 8,0 


SET UF TO RETURN TO HALT INSTRUCTION 
;FUSH RETURN АШК 

SACK SPACE 

ТАБ 

sLINE FEEL 

? САККТАСЕ RETURN 

PELEAR PAGE / FORM FEED 

$CURSOR UF 

$CUZSÜR DOWN 

ў СОКЭОК RIGHT 


5С0К50К LEFT 


E 10 ENU OF SCREEN 
5ЕКА5Е TO END OF LINE 
sCLEAR РАСЕ / FORM FEEL 


$UNIMFLEMENTED CONTROL CHARACTER. +. IGNORE 


$»SET UP TO COMPARE CURRENT LINE NUMBER... 
ъв WITH LAST LINE IN BUFFER 

51Е THEY MATCH? MUST SCROLL UF 
OTHERWISE: MOVE TO NEXT LINE 

91S ІТ AT BOTTOM OF BUFFER ? 

INO -- SKIP AROUMU NEXT INSTRUCTION 

FYES -- SET LINE NUMBER Tu TUF OF BUFFER 


i1 


LFRT 


Су че + 
2 


SCR2 


LD 
DUT 
LI 
LI 
RL 
RR 
RR 
SET 
RET 


Е,А 
(UCLINE)»Ó 
Ln 

HrE 

L 

H 

L 

43H 


CARRIAGE RETURN 


LI 
LI 
OUT 
LI 
AND 
LI 
RET 


D,9 

буй 
CWCCHAR )s À 
Ay вон 

L 

Ls 


LEFT / BACKSFACE 


+EQU 


LI! 
CF 
RET 
ПЕС 
ПЕС 
LI 
QUT 
RET 


% 

а,0 

р 

2 

р 

HL. 

GERY 
(4ССНАК ›,А 


MOVE CURSOR RIGHT 


LI буй 

INC ^ 

СЕ NUMCOL 
RET 2 

INC I 

INC HL 

QUT CWCCHAR 7A 
RET 

SCROLL UF 

INC B 

Ln А,В 

СЕ NUMROW 
JR М2»5СК2 
LI TIU 

LI 1,0 

LD НЕ 

RR H 

RR L 

SET 40H 

Ln С, BLANK 
LI А,80 
ADD ам 


9’E’ CONTAINS LINE МО. 


IN... 


$CONVERT ROW ANT! COLUMN INTO ADOR 
fee REFRESH MEMORY» SINCE LIMES AR 
$4 COLUMNS LONG 


ЗЕТ COLUMN NUMBER TO ZERO 


»CLEAN UF REFRESH MEMORY ADDRESS 


? МОУЕ CURSOR LEFT 

зваск SPACE 

ТЕ COLUMN WAS ZERO... 

$...ATTEMFT TO MOVE OFF OF SCREEN 
70.8. ТО DECREMENT COLUMN NUMBER 

КЕСЕ MEMORY РОІМТЕК CORRECT ALSO 
TELL 5027 WHAT WE'RE DOING 50 THAT... 
$ee CURSOR WILL BE CORRECT 


$COFY COLUMN COUNTER ANI... 

fee INCREMENT COFY IN ‘A’ © 
5010 WE MOVE OFF OF SCREEN 7 
ҮЕР -- FORGET THE MODIFICATION 
$INCREMENT COLUMN ANDO «++ 

$ ee MEMORY POINTERS 

?КЕЕР 5027 INFORMED 


$ INCREMENT LAST DISFLAYED LINE 

3SET UF ТО СОМРАКЕ 

318 NEW ROW LAST ROW IN MEMORY ? 

? МОРЕ 

5ҮЕ5 -- WRAF ^B' REG AROUND 

SET UF MEMORY POINTER FROM KOW»COL. 


{БЕТ UP TO FILL NEW LINE WITH BLANKS 
$CALCULATE АПИКЕ55 OF LAST CHAR... 
$...IN LINE FOR LOOF TERMINATION 


SW3LSASOHOIW 001-5 


56 


ӘСКЕР LD сно», ФЕТ WITH BLANKS PLACE LI HE БЕТ UP DISPLAY MEMORY ADDRSS IN H/L... 
INC HL Ln Lol $ee USING D/E DATA 
CP L RL L 
JR NZ»SCRLP RR H 
Ln AB RR L 
OUT ( REGS од ЎСНАМСЕ LAST DISPLAYED LINE ADDRESS IN 5027 574 2 
LINE FEED : Жа , 
КЕТ FERD (ROUTINE: EXFEGTS THIS: БЕШІЕ OUT (WCCHAR за $PLACE CURSOR HERE BY TELLING 5027 
! LD AJE 
CLEAR SCREEN бит CWCLINE 9A 
; КЕТ 
CLEAR їп ^; 08H THIS IS FUNNY HARDWARE HACK TO DISABLE IMA... ? 
OUT (10H 9A $ee FOR 5027 (I THINK) aes н НОМЕ 
Ln НЬ» DISPMEM $STARTING ADDRESS : 
Lh C» BLANK $BLANK CHARACTER HOME — Ln 7,0 COLUMN IS ZERO АТ HOME 
CLRI ш Ay 50H SLOOP TERMINATION TEST VALUE Ln а, В SUSE LAST DISPLAYED LINE PLUS ONE AS HOME ROW 
CLR Lo CHL eC $CLEAR LOOF | INC 8 
INC HL СР NUMROW $18 ІТ OUT OF THE BUFFER (WRAF AROUND) ? 
cP L JR NZ»HOLP 
JR NZrCLR Ln 8,0 ;jYES -- LOAD ZERO 
Ln A» ODOH iNEM LOOF TERMINATION VALUE << ?T??? HOLP — Ln Е,А ФИ5Е CALCULATED VALUE FOR ROW 
CLR2 — Ln CHLC ЎМОТЕ THAT SOME OF THE DISPLAY RAM IS USED CALL PLACE PLACE CURSOR IN DESIRED LOCATION 
INC HL за. „ЕОК FIRMWARE ВООККЕЕРІМЕ» SO MUST BE... — KEN 
CF L $s e PROTECTED! FROM CLEAR 
JR NZ»CLR2 T 
LI а, 1вн $NOU; ШЕ TEST НО, FINALLY н CURSOR CONTROL ROUTINES 
СР H $ 
JR ма сока SIF NOT DONE, START AGAIN AT /С1Б1/ GOXY СР 210 5747 18 X-CONTROL, ‘>=’ IS Y-CONTROL 
CALL HOME $DONE -- HOME CURSOR JF MyXCNTL 
Lh &»20H БЕТ UF 5027 DMA AGAIN (I THINK) SUE 210 THIS IS Y-CONTROL CHAR 
OUT (10H А СР NUMROW CHECK VALUE < NUMBER OF ROWS 
RET JP РУНЕТ INVALID» SO IGNORE 
; ann а» В ADD ROW + TO LAST DISP ROW 
i CURSOR UP ONE LINE INC А 
; СР NUMROW 518 IT OUTSIDE OF BUFFER (WRAP AROUND) 
UFLINE LI AE 900 WE HAVE TO MOVE UF ЧАР АЕ + MONE JP My SKIF2 
СР 0 AME TC RUNE UP йы йы MODE 7 SUE NUMROU ;jYES -- SUBSTITUTE VALUE 
JR NZ»UFLF $NÜPE -- NORMAL NUMBER SKIP2 LD Е,А FUSE МЕШ ROW VALUE 
LI Ay NUMROW $YES -- SUESTITUTE LARGES юм СА. | FLACE PLACE CURSOR CORRECTLY 
UPLF DEC ^ SDECREMENT IN EITHER САБЕН Sane нын ЈР HLT #FINISHED 
СР B вото WE MOVE ‘UP’ INTO LOWEST LINE ON SCREEN p XCNTL SUB 128 COLUMN CODE STARTS HERE 
RET 2 #YES -- IGNORE ATTEMPT TO MOVE OFF OF SCREEN | СЕ re 
LD ЭР VALUE IS OK, -- SAVE IT ih JP РУНЬТ $GREATER THAN VALID COLUMN 
CALL PLACE РАСЕ CURSOR AT LOCATION IN D/E Ln уд 3М0 OTHER CHECKS REQUIRED -- PLACE CURSOR 
RET un CALL ^ PLACE 
i JP HLT 
i CURSOR [OWN ONE LINE ! 
ÜNL INE | нэг 
Е | А,Е ЗАК YING 5 ым єп н , 
СР B VARE; ШЕ, TRYING TO MOVE. DOUN. EROE LABT GENE T! Жі LD А›ОЕВН ;MASK TO MAKE COLUMN COUNTER A MULT OF 8 
RET 2 PYES -- IGNORE ATTEMPT TO MOVE OFF OF SERTE AND р SAND WITH MASK TO CLEAR LOW 3 BITS 
CP NUMROU- 1 900 WE HAVE TO WRAP AROUND BUÉPER A шлан ADD fi; 08H PADD 8 
JR NZ»DNLP CP NUMCOL #ОЕЕ END OF LINE ? 
LD бу OFFH PYES -- PRE-LOAD DUMMY VALUE RET z YES -- IGNORE 
DNLF тме à $INCREMENT ROW IN ANY CASE 
Lh Е,А 558МЕ NEU VALUE 
CALL PLACE PLACE CURSOR AT LOCATION IN пие LI пуа МО -- PLACE CURSOR НЕКЕ 
BET CALL РЬАСЕ 
RET 


PLACE CURSOR AT POSITION SPECIFIED IN ПУ AND “Е 
^p^ IS COLUMN NUMBER» Е“ IS LINE NUMBER 


w w 


ЕО р 
PUSH 
Lo 
EEOLL Lit 
INC 
INC 
CF 
JR 
FOP 
RET 


ETL эх o 


, 
ЕЕО5 
EEOSL 


FUSH 
CALL 


ERASE TO ЕМП 


ERASE TO END ОҒ LINE 


буй 

HL. 

С, BLANK 
СН. УУС 

а 

HL 
NUMCOL 
NZ:EEOLL 
HL. 


OF SCREEN 


ПЕ 

EEOL 

1,0 
INLINE 
А,В 

Е 
NZsEEOSL 
EEOL. 

ПЕ 

FLACE 


%СОРҮ COLUMN NUMBER INTO ‘A’ 


САМЕ OLI! 
SFOR LOOF 


560 UNTIL 
? СЕТ OLI! 


CURSOR ADDRESS 
SPEED 


“а” 
CURSOR АІШКЕ55 


IS EQUAL TO 80 


55АМЕ OLD ROU/COLUMN VALUES 
?ЕКАЗЕ TO END OF CURRENT LINE 


FROM NOW ON; 


GO TO NEXT LINE DOWN 


ERASE ENTIRE LINE 


915 CURRENT ROW THE FINAL ROW IISFLAYED ? 


МОРЕ -- 


60 ERASE 


ANOTHER LINE 


500 FINAL LINE ERASE О0ТБІШЕ OF LOOF 
? КЕЗТОКЕ REAL ROW/COLUMN VALUES 


;SET CURSOR UF 


AN 8080 DIASASSEMBLER 
Continued from page 52 


0 DW 4022H 
OF1CH DB 0 

10H DW 1CH 
OCOOH DB 10H 
80H DW 0COOH 
890BH DB 80H 
20H DW 897CH 
0D494H DB 20H 

0 DW 0D494H 
594H DB 0 

0 DW 4093H 
1В00Н ОВ 0 

0 DW 1800H 
554H DB 0 

10H DW 4053H 
1500H DB 10H 

0 DW 402AH 
SICH DB 0 

10H DW 401BH 
922CH DB 10H 

0 DW 922CH 
89c4H DB 0 

20H DW 91CH 
0D494H DB 20H 

0 DW 0D494H 
94H DB 0 

0 ; 4-CHARACTER MNEMONIC TABLE 
0D083H TBX: DW 9D 58H 
80H DB 1 

54Н DW 6158H 
10H DB 1 


CORKECTL Y 


PLOC: DS 
РС1: рѕ 
РС2: рѕ 
РСЗ: DS 
PLAB: DS 
PMNE: DS 
PARG: DS 


9А44Н 
OCH 
6244H 
OCH 
8548H 
53H 
184CH 
4CH 

OC 54CH 
8 
0C047H 
OC 8H 
9C4CH 
8 
804CH 
0C8H 


к су OY GO C2 CO (л 


. 
, 


OUTPUT BUFFER 


5-100 MICROSYSTEMS 


CHARTER SUBSCRIPTION OFFER! 
SAO 


MICRO SYSTEMS 


THE ONLY MAGAZINE BY AND FOR 5-100 SYSTEM USERS! 
TAKE ADVANTAGE OF THIS LIMITED Eea 
TIME CHARTER SUBSCRIPTION OFFER! MICRO SYSTEMS 


At last there is a magazine written exclusively for 5-100 system users. JAN/FEB 1980 2 
No other publication is devoted to supporting 5-100 system users. No VOL. И МО1 
longer will you have to hunt through other magazines for an 

occasional 5-100, CP/M* or PASCAL article. Now find it all in one 

publication. Find it in 5-100 MICROSYSTEMS. 


SOFTWARE HARDWARE SYSTEMS 
CP/M* 8 bit & 16 bit CPUs Cromenco 
Assembler interfacing North Star 
BASIC hardware mods IMSAI 
PASCAL bulletin board systems SOL 
applications multiprocessors Polymophics 
and lots more and lots more and lots more 


Every issue of S-100 MICROSYSTEMS brings you the latest in the 
5-100 world. Articles on applications, tutorials, software 
development, letters to the editor, newsletter columns, book 
reviews, new products, etc. Material to keep you on top of the 
ever changing microcomputer scene. 


*Registered Trademark Digital Research 


Ола more 
мяг ag 


Published every other month 


Take advantage of our low charter subscription offer right 
now! This offer runs out on April 30, 1980. Edited by Sol Libes and Russell Gorr 


Foreign: $20 per year only 
Foreign Air Mail add $12. Clip and mail to: S-400 MICROSYSTEMS 


Р.О. Box 1192 Mountainside, NJ 07092 


R | 
[] Bill me 
ec | Send me . [ssues of ~ «тт 
1 | 456 issue 
(e | MICROSYSTEMS — ^ 
Ape? | enclosed 
«08° ” 
сувд | Мате 
хо! | 
| Address 
No. of Payment 
Нина Bill Ме enclosed | City 
6 issues 5 800 5750 | 
12 Issues (2 yrs) (1500 14.00 | 
18 issues (3 yrs.) 23.00 21.50 | State Zip 
| 
Canada: $9.00 per year U.S. Funds | СРО Disk System 
| 
| 
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NEW PRODUCTS 


NEW S-100 ROM-RAM-I/O BOARD AVAILABLE 


ELECTRONIC CONTROL TECHNOLOGY, 763 
Ramsey Ave, Hillside NJ 07205 has 
available the model R2I/O board, 5-100 
Computer Systems. It features 3 serial 
I/O ports, 1 parallel I/O port, 4 status 
ports, 2K of ROM and 2K of RAM. The 
R2I/O provides a means of interfacing 
several I/O peripherals such as CRT 
terminals, line printers, modems or 
other devices, to an S-100 Computer. 

It also provides computer control 
from a terminal with a ROM-based Monitor 
program containing Executive commands 
and I/O routines. ТЕ can also be used 
in dedicated control applications with a 
minimum number of boards since it 
contains ROM, RAM and I/O. Baud rates 
are individually selectable from 75-9600 
baud and serial I/O ports feature RS-232 
compatibility. All ICs are socketed and 
the board is available for $295 


assembled and tested. 


HIGH SPEED FOUR CHANNEL 12-BIT DAC BOARD 


A high speed four channel 12-bit 
Digital-to-Analog Converter board Паз 
been introduced by TECMAR INC., 23414 
Greenlawn Avenue, Cleveland Ohio 44122. 
The board features four completely 
independent high speed DACs and 
associated latches. The DACs have a 
typical conversion time of 3 usecs. Тһе 
use of latch driven inputs allows the 
DAC to hold its previous input until an 
entirely new word is presented to it. 
The board features user-selectable 
output voltage ranges 0 to +5V, 0 to 
+10V, %2.5У, %5У, +10V. The board may 
be addressed аз I/O ports or memory 
mapped. It comes assembled, tested and 
completely socketed and is $395. The 
technical manual alone is $15. 
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FCC APPROVED S-100 MODEM BOARD 


POTOMAC MICRO-MAGIC INC., First 
Lincolnia Building, Suite Bl, 4810 
Beauregard Street, Alexandria, Va 22312 
had introduced an S-100 compatible modem 
board. The MM-103, allows commercial 
quality communications at an affordable 
price. The board utilizes sophisticated 
modem IC and associated circuitry. 
Electronic features of the MM-103 
include: positive carrier detection and 
loss of carrier disconnect, 5MHz 
operation without wait states, variable 
baud rate of over 200 values for 61 to 
600 baud, 50 db sensitivity, 10 DB S/N 
and allows for speed dialing when 
available from phone company. The board 
features the most extensive software 
Support of any data communications 
interface for S-100 Computer Systems. 
Included is the source code for over 30 
programs as well as diskettes for North 
Star DOS, North Star CP/M, 8" CP/M, and 
Micropolis II. The MM-103 is the first 
5-100 Modem approved by the FCC for 
direct connection to the phone System 
without the use of DAA device (CBS or 
CBT). Тһе modem is available assembled 
and tested for $395. 


S-100 MICROSYSTEMS 


2 b Мисс Data Base Systems, inc. 


THE DATA BASE SPECIALIST 


HDBS - HIERARCHICAL DATA BASE MANAGEMENT SYSTEM 
MDBS - OUR FULL NETWORK DATA BASE MANAGEMENT SYSTEM 


ADDITIONAL FEATURES IN MDBS 


ө HIERARCHICAL AND FULL NETWORK DATA STRUC- е EXPLICIT REPRESENTATION OF ONE-TO-ONE, ОМЕ- 
TURES (CODASYL ORIENTED) TO-MANY, MANY-TO-ONE AND MANY-TO-MANY SETS 


* FIXED AND VARIABLE LENGTH RECORDS * RECORD TYPES MAY OWN OTHER OCCURRENCES 


* MULTIPLE LEVELS OF READ/WRITE PROTECTION OF THE SAME RECORD TYPE 
AT ITEM, RECORD, SET AND FILE LEVELS * ASINGLE SET MAY HAVE MULTIPLE OWNER AND 
MEMBER RECORD TYPES 


HDBS FEATURES 


* HIERARCHICAL DATA STRUCTURES 

* FIXED LENGTH RECORDS 

ө READ/WRITE PROTECTION AT FILE LEVEL 

» ONE-TO-MANY SET RELATIONSHIPS ALLOWED 


FEATURES COMMON TO HDBS and MDBS 


STRAIGHT FORWARD USE OF ISAM-LIKE STRUCTURES 
SORTED, FIFO, LIFO, NEXT AND PRIOR SET ORDERING PROVIDED 

COMMANDS TO ADD, DELETE, UPDATE, SEARCH AND TRAVERSE THE DATA BASE 

NAMES OF DATA ITEMS, RECORDS, SETS AND FILES ARE WHOLLY USER DEFINABLE 

RECORDS CAN BE MAINTAINED IN A NUMBER OF SORTED ORDERS 

ROUTINES ARE CALLABLE FROM BASIC, PASCAL, FORTRAN, COBOL OR MACHINE LANGUAGE 

WRITTEN IN MACHINE LANGUAGE FOR MAXIMAL EXECUTION EFFICIENCY AND MINIMAL MEMORY USAGE 

SUPPORTS DATA BASE SPREAD OVER SEVERAL DISK DRIVES (MAX. 8) DISKS MAY BE MINI OR FULL SIZED FLOPPIES OR HARD DISKS 
Also 
UP TO 254 RECORD-TYPES MAY BE DEFINED IN THE DATA BASE 
EACH RECORD-TYPE MAY CONTAIN UP TO 254 ITEM-TYPES 
EACH ITEM-TYPE MAY BE UP TO 9,999 BYTES IN LENGTH 


REQUIREMENTS NEW DYNAMIC 


* Z-80 APPROXIMATELY 16K MEMORY — RESTRUCTURING SYSTEM 
e 8080 APPROXIMATELY 20K MEMORY— 


* IN ADDITION TO THE OPERATING SYSTEM, HOST LANGUAGE, MDBS-DRS FEATURES 
USER'S PROGRAM AND SOME BUFFER AREA Кю К УУ Г жартыны 
* 6502 APPROXIMATELY 26K MEMORY ALLOWS ITEM, RECORD AND/OR SET TYPES TO 
BE ADDED TO OR DELETED FROM AN EXISTING 


MDBS DATA BASE. THIS ALLOWS THE USER TO 
—— —— RUE RE-DESIGN A DATA BASE AFTER IT IS ALREADY 


DDL DATA DEFINITION LANGUAGE ANALYZER/EDITOR. The user specifies data struc- ON-LINE. 

tures to be used іп a Concise Data Definition Language (DDL). The Data Definition Language 

Analyzer/Editor allows the user to interactively create and edit DDL Specifications and to 

initialize the data base for use based on these specifications. THIS FEATURE CAN ONLY BE ADDED TO THE 
PAGE USERS MANUAL with extensive documentation of the Data Base Management MDBS SYSTEM. 

DMS DATA MANAGEMENT ROUTINES. These are the routines callable from the host RUNS UNDER 

language (BASIC, PASCAL, etc.) which perform the data base operations of finding, adding, 4 

and deleting records; fetching and storing data items; and traversing the (possibly complex) е CP/M* WITH MICROSOFT BASIC, COBOL AND 

data structure. FORTRAN 

SAMPLE APPLICATION PROGRAM AND DDL FILES * NORTHSTAR DOS WITH NORTHSTAR BASIC 

RELOCATOR TO RE-ORG ALL ROUTINES е THSDOS" AND DISK BASIC 

RELOCATOR TO RE-ORG ALL ROUTINES » NEWDOS AND DISK BASIC 

SYSTEM SPECIFIC MANUAL to show how to bring up our software on your computer e APPLE* DOS AND APPLE* SOFT BASIC 


* MACHINE LANGUAGE CALLABLE FORMS 
e OTHER FORMS IN DEVELOPMENT 


HDBS — 280 VERSION 


8080 and 6502 VERSIONS $325 E 
MANUAL ONLY $ 35 — 
WE ACCEPT 
UPGRADE TO MDBS $550 ж 
MDBS - 280 Version 5750 MICRO DATA BASE SYSTEMS, INC 
8080 and 6502 VERSIONS $825 


FOR FREE PRIMER 
CONTACT MDBS. 


P.O.BOX 248 LAFAYETTE, IN 47902 
(317) 742-7388 


MANUAL ONLY $ 35 


MACHINE LANGUAGE CALLABLE 
FORMS ADD $ 75 А400 $2.50 ($5.00 IF FOREIGN) 
Элс на з ____————————є—=— "TO .NON-CASH ORDERS FOR 
MBBS- DRS $100 HANDLING AND SHIPPING. 
MANUAL ONLY $ 5 INDIANA RESIDENTS ADD 4%. 


CP/M is a registered trademark of Digital Research Corp. 
TRS-80 is a registered trademark of Radio Shack/Tandy Corp. 
Apple is a registered trademark of Apple Computers, Inc. 


СОМРЫРНО" CONTINUES ТО 
DELIVER. 


Whether it’s memory, motherboards, I/O boards, enclosures, or any of our fam- 
ily of products, CompuPro™ delivers what you want at prices you can afford. 

Looking for memory? Our boards are fully static, low power, run at 4 or 5 MHz, 
support a number of popular busses, include a 1 year limited warranty, and gen- 
erally come in 3 configurations to suit your exact needs. For lowest cost, choose 
an “unkit” with sockets and bypass caps pre-soldered in place for easy assembly. 
When you can’t wait to get going, order one of our assembled versions. For critical 
systems, specify boards qualified under our Certified System Component (CSC) 
high reliability program. These boards are extensively tested, burned in for at least 
200 hours, and are immediately replaced in event of failure within 1 year of invoice 
date. 

Looking for other peripherals? We mix leading edge technology, design savvy, 
and volume buying to deliver the right product at the right price. See our list 
below for pricing. 


16K DYNAMIC RAMS 
8/$87.20! 


Perfect for memory expansion in a number 
of machines (TRS-80** Model | and Model Il, 
Exidy Sorcerer, Heath H89, Apple, etc.), and you 
can’t beat our price: 8 high speed chips for $64! 
Add $3 if you'd like 2 dip shunts plus TRS-80* * 
programming instructions to expand memory. 
These are 250 ns (4 MHz), dynamic RAMs...but 
quantities are limited, so hurry is you want to 
take advantage of this super deal. 

**TRS-80 is a trademark of the Tandy Corporation. 


PASCAL/M'" + 
MEMORY SPECIAL 


PASCAL can give a microcomputer with CP/M 
more power than many minis. For a limited time 
only, you can buy an assembled Econoram X, plus 
our totally standard Wirth PASCAL/M"" 8" diskette, 
for $799 (regular combined price, $999). Includes 
manual, plus Wirth's definitive book on PASCAL; 
specify 2-80 or 8080/8085 version. Diskette is also 
available separately for $350. 


2708 EROM 
BOARD 585 unkit 


4 independently addressable 4K blocks, with dip- 
Switch selectable jump start built right into the 
board. Includes all support chips and manual, but 
does not include EROMs. 


13-100 MEMORY 


Buss & Notes Unkit Assm CSC 


S-100 $149 $179 $239 
5-100 5289 5339 5429 
5-100 5299 5349 5439 
5-100 5419 5499 5605 
Dig Grp $319 $379 п/а 
Dig Grp $559 $639 n/a 
S-100 $549 $669 $789 
SBC/BLC n/a n/a $1050 
S-100 (1) $349 $419 $519 
S-100 (1) $469 $539 $649 
S-100 (1) $579 $699 $849 
S-100 (2) $299 $359 $459 
16K Econoram XV-16 H8 (3) $329 $395 n/a 
32K Econoram XV-32 H8 (3) $599 $729 n/a 


*Econoram is a trademark of Godbout Electronics 

(1) Compatible with all bank select systems (Cromemco, Alpha Micro, etc.); addressable on 4K 
boundaries. 

(2) Extended addressing (24 address lines). Single block addressable on 4K boundaries. 

(3) Bank select option for implementing memory systems greater than 64K. 


Memory name 


8К Econoram* ПА 
16K Econoram IV 
16K Econoram VIIA-16 
24K Econoram УПА-24 
16K Econoram 1Х-16 
32K Econoram ІХ-32 
32K Econoram X 
32K Econoram XI 
16K Econoram XIIIA-16 
24K Econoram XIIIA-24 
32K Econoram XIIIA-32 
16K Econoram XIV 


$59 unkit 
$85 assm 


MANAGER BOARD s100 сс 


Add bank select and extended addressing to older S-100 machines 
(Altair, IMSAI, Sol, and others). Use with our new extended addressing 
boards, or retrofit our high density Econorams for use with the Memory 


THESE PRODUCTS ARE GENERALLY 
AVAILABLE FROM YOUR LOCAL 
COMPUTER STORE. 


ACTIVE TERMINATOR 


Manager to get added memory space for your computer. 


MULLEN 5-1ОО 


BOARD $34.50 ки 


Plugs into any S-100 motherboard (although ours don't need it) to re- 
duce ringing, crosstalk, noise, and other buss-related problems. 


THE GODBOUT 
COMPUTER BOX 


$259 desktop, $299 rack mount (introductory price) 

The ideal home for your computer. With fan, dual AC outlets and 
fuseholder, power switch, heavy-duty line filter, black anodized front 
panel (with textured vinyl painted cover for desk top version); pre-drilled 
base accepts our high-performance motherboards or similar types by 
Vector, California Digital, and others. Rack mount version includes 
slides for easy pull-out from rack. This functional, versatile, and hand- 
some enclosure does justice to the finest computer systems. 


HIGH-PERFORMANCE 
S-100 MOTHERBOARDS 


6 slot: $ 89unkit, $129 assm 12 slot: $129 unkit, $169 assm 
19 slot: $174 unkit, $214 assm 
Unkits have edge connectors and termination resistors pre-soldered 
in place for easy assembly. These boards exceed the latest S-100 
specs and will work with 5 to 10 MHz CPUS. Includes true active termi- 
nation, grounded Farady shield between all buss signal lines, and edge 
connectors for all slots. 


ompuPro" som 00290 


Bldg. 725, Oakland Airport, СА 94614 


$49 
EXTENDER BOARD kit 


Includes logic probe and general purpose breadboard section. Ideal 
for troubleshooting and analysis. 


ЗР PLUS S 
“Interfacer I 
33-100 ПО BOARD 


Incorporates 1 channel of serial /О (RS-232 with full handshake), 
along with 3 full duplex parallel ports plus a separate status port. The 
parallel section uses Tri-State (tm National Semiconductor) octal 
latches for latched data, input and output with 24 mA drive current, 
attention/enable/strobe bits for each parallel port (with selectable 
polarity), interrupts for each input port, and separate connectors with 
power for each channel. 


2S *Interfacer I" dy dein 
13-100 ПО BOARD :4csc 


Dual RS-232 ports with full handshake; use EIA232C line drivers and 
receivers (1488, 1489), or current loop (20 mA), or TTL signals on both 
ports. On-board crystal timebase with independently selectable Baud 
rates for each port (up to 19.2 KBaud). Hardware UARTs don't tie up the 
CPU. 


$199 unkit 
$249 assm 
$324 CSC 


$199 unkit 


TERMS: Cal res add tax. Allow 5% for ship- 
ping, excess refunded. VISA® /Mastercharge* 
call our 24 hour order desk at (415) 562-0636. 
COD OK with street address for UPS. Prices 
good through cover month of magazine. 


